利用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中将嵌套列表扁平化的多种实现方法》在Python编程中,我们常常会遇到需要将嵌套列表(即列表中包含列表)转换为一个一维的扁平列表的需求,本文将给大家介绍了多种实现这一目标的方法,需要的朋... 目录python中将嵌套列表扁平化的方法技术背景实现步骤1. 使用嵌套列表推导式2. 使用itert

Python使用pip工具实现包自动更新的多种方法

《Python使用pip工具实现包自动更新的多种方法》本文深入探讨了使用Python的pip工具实现包自动更新的各种方法和技术,我们将从基础概念开始,逐步介绍手动更新方法、自动化脚本编写、结合CI/C... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核

在Linux中改变echo输出颜色的实现方法

《在Linux中改变echo输出颜色的实现方法》在Linux系统的命令行环境下,为了使输出信息更加清晰、突出,便于用户快速识别和区分不同类型的信息,常常需要改变echo命令的输出颜色,所以本文给大家介... 目python录在linux中改变echo输出颜色的方法技术背景实现步骤使用ANSI转义码使用tpu

Python使用python-can实现合并BLF文件

《Python使用python-can实现合并BLF文件》python-can库是Python生态中专注于CAN总线通信与数据处理的强大工具,本文将使用python-can为BLF文件合并提供高效灵活... 目录一、python-can 库:CAN 数据处理的利器二、BLF 文件合并核心代码解析1. 基础合

Python使用OpenCV实现获取视频时长的小工具

《Python使用OpenCV实现获取视频时长的小工具》在处理视频数据时,获取视频的时长是一项常见且基础的需求,本文将详细介绍如何使用Python和OpenCV获取视频时长,并对每一行代码进行深入解析... 目录一、代码实现二、代码解析1. 导入 OpenCV 库2. 定义获取视频时长的函数3. 打开视频文

golang版本升级如何实现

《golang版本升级如何实现》:本文主要介绍golang版本升级如何实现问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录golanwww.chinasem.cng版本升级linux上golang版本升级删除golang旧版本安装golang最新版本总结gola

SpringBoot中SM2公钥加密、私钥解密的实现示例详解

《SpringBoot中SM2公钥加密、私钥解密的实现示例详解》本文介绍了如何在SpringBoot项目中实现SM2公钥加密和私钥解密的功能,通过使用Hutool库和BouncyCastle依赖,简化... 目录一、前言1、加密信息(示例)2、加密结果(示例)二、实现代码1、yml文件配置2、创建SM2工具

Mysql实现范围分区表(新增、删除、重组、查看)

《Mysql实现范围分区表(新增、删除、重组、查看)》MySQL分区表的四种类型(范围、哈希、列表、键值),主要介绍了范围分区的创建、查询、添加、删除及重组织操作,具有一定的参考价值,感兴趣的可以了解... 目录一、mysql分区表分类二、范围分区(Range Partitioning1、新建分区表:2、分

MySQL 定时新增分区的实现示例

《MySQL定时新增分区的实现示例》本文主要介绍了通过存储过程和定时任务实现MySQL分区的自动创建,解决大数据量下手动维护的繁琐问题,具有一定的参考价值,感兴趣的可以了解一下... mysql创建好分区之后,有时候会需要自动创建分区。比如,一些表数据量非常大,有些数据是热点数据,按照日期分区MululbU