利用AsyncHttpClient实现图片的上传与下载+进度条

2024-05-16 10:48

本文主要是介绍利用AsyncHttpClient实现图片的上传与下载+进度条,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

利用AsyncHttpClient实现图片的上传与下载+  进度条

图片上传

[java]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1.       /** 
  2. * @param path 
  3. *            要上传的文件路径 
  4. * @param url 
  5. *            服务端接收URL 
  6. * @throws Exception 
  7. */  
  8. public static void uploadFile(String path, String url) throws Exception {  
  9. File file = new File(path);  
  10. if (file.exists() && file.length() > 0) {  
  11.     AsyncHttpClient client = new AsyncHttpClient();  
  12.     RequestParams params = new RequestParams();  
  13.     params.put("uploadfile", file);  
  14.     // 上传文件  
  15.     client.post(url, params, new AsyncHttpResponseHandler() {  
  16.         @Override  
  17.         public void onSuccess(int statusCode, Header[] headers,  
  18.                 byte[] responseBody) {  
  19.             // 上传成功后要做的工作  
  20.             Toast.makeText(mContext, "上传成功", Toast.LENGTH_LONG).show();  
  21.             progress.setProgress(0);  
  22.         }  
  23.   
  24.         @Override  
  25.         public void onFailure(int statusCode, Header[] headers,  
  26.                 byte[] responseBody, Throwable error) {  
  27.             // 上传失败后要做到工作  
  28.             Toast.makeText(mContext, "上传失败", Toast.LENGTH_LONG).show();  
  29.         }  
  30.   
  31.         @Override  
  32.         public void onProgress(int bytesWritten, int totalSize) {  
  33.             // TODO Auto-generated method stub  
  34.             super.onProgress(bytesWritten, totalSize);  
  35.             int count = (int) ((bytesWritten * 1.0 / totalSize) * 100);  
  36.             // 上传进度显示  
  37.             progress.setProgress(count);  
  38.             Log.e("上传 Progress>>>>>", bytesWritten + " / " + totalSize);  
  39.         }  
  40.   
  41.         @Override  
  42.         public void onRetry(int retryNo) {  
  43.             // TODO Auto-generated method stub  
  44.             super.onRetry(retryNo);  
  45.             // 返回重试次数  
  46.         }  
  47.   
  48.     });  
  49. else {  
  50.     Toast.makeText(mContext, "文件不存在", Toast.LENGTH_LONG).show();  
  51. }  


图片下载

[java]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1.       /** 
  2. * @param url 
  3. *            要下载的文件URL 
  4. * @throws Exception 
  5. */  
  6. public static void downloadFile(String url) throws Exception {  
  7.   
  8. AsyncHttpClient client = new AsyncHttpClient();  
  9. // 指定文件类型  
  10. String[] allowedContentTypes = new String[] { "image/png""image/jpeg" };  
  11. // 获取二进制数据如图片和其他文件  
  12. client.get(url, new BinaryHttpResponseHandler(allowedContentTypes) {  
  13.   
  14.     @Override  
  15.     public void onSuccess(int statusCode, Header[] headers,  
  16.             byte[] binaryData) {  
  17.         String tempPath = Environment.getExternalStorageDirectory()  
  18.                 .getPath() + "/temp.jpg";  
  19.         // TODO Auto-generated method stub  
  20.         // 下载成功后需要做的工作  
  21.         progress.setProgress(0);  
  22.         //  
  23.         Log.e("binaryData:""共下载了:" + binaryData.length);  
  24.         //  
  25.         Bitmap bmp = BitmapFactory.decodeByteArray(binaryData, 0,  
  26.                 binaryData.length);  
  27.   
  28.         File file = new File(tempPath);  
  29.         // 压缩格式  
  30.         CompressFormat format = Bitmap.CompressFormat.JPEG;  
  31.         // 压缩比例  
  32.         int quality = 100;  
  33.         try {  
  34.             // 若存在则删除  
  35.             if (file.exists())  
  36.                 file.delete();  
  37.             // 创建文件  
  38.             file.createNewFile();  
  39.             //  
  40.             OutputStream stream = new FileOutputStream(file);  
  41.             // 压缩输出  
  42.             bmp.compress(format, quality, stream);  
  43.             // 关闭  
  44.             stream.close();  
  45.             //  
  46.             Toast.makeText(mContext, "下载成功\n" + tempPath,  
  47.                     Toast.LENGTH_LONG).show();  
  48.   
  49.         } catch (IOException e) {  
  50.             // TODO Auto-generated catch block  
  51.             e.printStackTrace();  
  52.         }  
  53.   
  54.     }  
  55.   
  56.     @Override  
  57.     public void onFailure(int statusCode, Header[] headers,  
  58.             byte[] binaryData, Throwable error) {  
  59.         // TODO Auto-generated method stub  
  60.         Toast.makeText(mContext, "下载失败", Toast.LENGTH_LONG).show();  
  61.     }  
  62.   
  63.     @Override  
  64.     public void onProgress(int bytesWritten, int totalSize) {  
  65.         // TODO Auto-generated method stub  
  66.         super.onProgress(bytesWritten, totalSize);  
  67.         int count = (int) ((bytesWritten * 1.0 / totalSize) * 100);  
  68.         // 下载进度显示  
  69.         progress.setProgress(count);  
  70.         Log.e("下载 Progress>>>>>", bytesWritten + " / " + totalSize);  
  71.   
  72.     }  
  73.   
  74.     @Override  
  75.     public void onRetry(int retryNo) {  
  76.         // TODO Auto-generated method stub  
  77.         super.onRetry(retryNo);  
  78.         // 返回重试次数  
  79.     }  
  80.   
  81. });  


PHP服务端

[php]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. <?php  
  2. $base_path = "./upload/"// 接收文件目录  
  3. $target_path = $base_path . basename ( $_FILES ['uploadfile'] ['name'] );  
  4. if (move_uploaded_file ( $_FILES ['uploadfile'] ['tmp_name'], $target_path )) {  
  5.     $array = array (  
  6.             "code" => "1",  
  7.             "message" => $_FILES ['uploadfile'] ['name']   
  8.     );  
  9.     echo json_encode ( $array );  
  10. else {  
  11.     $array = array (  
  12.             "code" => "0",  
  13.             "message" => "There was an error uploading the file, please try again!" . $_FILES ['uploadfile'] ['error']   
  14.     );  
  15.     echo json_encode ( $array );  
  16. }  
  17. ?>  

Service中类似的异常问题:

(com.zajt.zajtsafechat.http.AsyncHttpResponseHandler$ResponderHandler) {42843450} sending message to a Handler on a dead thread

解决办法:

 在Service中,AsyncHttpClient client = new SyncHttpClient();

 在Activity中,AsyncHttpClient client = new AsyncHttpClient();

其中SyncHttpClient是AsyncHttpClient的子类


这篇关于利用AsyncHttpClient实现图片的上传与下载+进度条的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/994699

相关文章

使用Python实现表格字段智能去重

《使用Python实现表格字段智能去重》在数据分析和处理过程中,数据清洗是一个至关重要的步骤,其中字段去重是一个常见且关键的任务,下面我们看看如何使用Python进行表格字段智能去重吧... 目录一、引言二、数据重复问题的常见场景与影响三、python在数据清洗中的优势四、基于Python的表格字段智能去重

Spring AI集成DeepSeek实现流式输出的操作方法

《SpringAI集成DeepSeek实现流式输出的操作方法》本文介绍了如何在SpringBoot中使用Sse(Server-SentEvents)技术实现流式输出,后端使用SpringMVC中的S... 目录一、后端代码二、前端代码三、运行项目小天有话说题外话参考资料前面一篇文章我们实现了《Spring

Nginx中location实现多条件匹配的方法详解

《Nginx中location实现多条件匹配的方法详解》在Nginx中,location指令用于匹配请求的URI,虽然location本身是基于单一匹配规则的,但可以通过多种方式实现多个条件的匹配逻辑... 目录1. 概述2. 实现多条件匹配的方式2.1 使用多个 location 块2.2 使用正则表达式

Python如何快速下载依赖

《Python如何快速下载依赖》本文介绍了四种在Python中快速下载依赖的方法,包括使用国内镜像源、开启pip并发下载功能、使用pipreqs批量下载项目依赖以及使用conda管理依赖,通过这些方法... 目录python快速下载依赖1. 使用国内镜像源临时使用镜像源永久配置镜像源2. 使用 pip 的并

jdk21下载、安装详细教程(Windows、Linux、macOS)

《jdk21下载、安装详细教程(Windows、Linux、macOS)》本文介绍了OpenJDK21的下载地址和安装步骤,包括Windows、Linux和macOS平台,下载后解压并设置环境变量,最... 目录1、官网2、下载openjdk3、安装4、验证1、官网官网地址:OpenJDK下载地址:Ar

使用Apache POI在Java中实现Excel单元格的合并

《使用ApachePOI在Java中实现Excel单元格的合并》在日常工作中,Excel是一个不可或缺的工具,尤其是在处理大量数据时,本文将介绍如何使用ApachePOI库在Java中实现Excel... 目录工具类介绍工具类代码调用示例依赖配置总结在日常工作中,Excel 是一个不可或缺的工http://

SpringBoot实现导出复杂对象到Excel文件

《SpringBoot实现导出复杂对象到Excel文件》这篇文章主要为大家详细介绍了如何使用Hutool和EasyExcel两种方式来实现在SpringBoot项目中导出复杂对象到Excel文件,需要... 在Spring Boot项目中导出复杂对象到Excel文件,可以利用Hutool或EasyExcel

SpringBoot集成图片验证码框架easy-captcha的详细过程

《SpringBoot集成图片验证码框架easy-captcha的详细过程》本文介绍了如何将Easy-Captcha框架集成到SpringBoot项目中,实现图片验证码功能,Easy-Captcha是... 目录SpringBoot集成图片验证码框架easy-captcha一、引言二、依赖三、代码1. Ea

Python如何实现读取csv文件时忽略文件的编码格式

《Python如何实现读取csv文件时忽略文件的编码格式》我们再日常读取csv文件的时候经常会发现csv文件的格式有多种,所以这篇文章为大家介绍了Python如何实现读取csv文件时忽略文件的编码格式... 目录1、背景介绍2、库的安装3、核心代码4、完整代码1、背景介绍我们再日常读取csv文件的时候经常

Golang中map缩容的实现

《Golang中map缩容的实现》本文主要介绍了Go语言中map的扩缩容机制,包括grow和hashGrow方法的处理,具有一定的参考价值,感兴趣的可以了解一下... 目录基本分析带来的隐患为什么不支持缩容基本分析在 Go 底层源码 src/runtime/map.go 中,扩缩容的处理方法是 grow