热门标签 | HotTags
当前位置:  开发笔记 > Android > 正文

Android上传文件到服务端并显示进度条

这篇文章主要介绍了Android上传文件到服务端,并显示进度条,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

最近在做上传文件的服务,简单看了网上的教程。结合实践共享出代码。

由于网上的大多数没有服务端的代码,这可不行呀,没服务端怎么调试呢。

Ok,先上代码。

Android 上传比较简单,主要用到的是 HttpURLConnection 类,然后加一个进度条组件。

private ProgressBar mPgBar; 
class UploadTask extends AsyncTask{ 
  private DataOutputStream outputStream = null; 
  private String fileName; 
  private String uri; 
  private String mLineEnd = "\r\n"; 
  private String mTwoHyphens = "--"; 
  private String boundary = "*****"; 
  File uploadFile ; 
  long mTtotalSize ; // Get size of file, bytes 
  public UploadTask(String fileName,String uri){ 
   this.fileName = fileName; 
   this.uri = uri; 
   uploadFile= new File(fileName); 
    mTtotalSize = uploadFile.length(); 
  } 
 
  /** 
   * 开始上传文件 
   * @param objects 
   * @return 
   */ 
  @Override 
  protected Void doInBackground(Object... objects) { 
   long length = 0; 
   int mBytesRead, mbytesAvailable, mBufferSize; 
   byte[] buffer; 
   int maxBufferSize = 256 * 1024;// 256KB 
   try{ 
 
    FileInputStream fileInputStream = new FileInputStream(new File(fileName)); 
 
    URL url = new URL(uri); 
 
    HttpURLConnection con = (HttpURLConnection) url.openConnection(); 
 
    //如果有必要则可以设置COOKIE 
//    conn.setRequestProperty("COOKIE","JSESSIOnID="+COOKIE); 
 
    // Set size of every block for post 
 
    con.setChunkedStreamingMode(256 * 1024);// 256KB 
 
    // Allow Inputs & Outputs 
    con.setDoInput(true); 
    con.setDoOutput(true); 
    con.setUseCaches(false); 
 
    // Enable POST method 
    con.setRequestMethod("POST"); 
    con.setRequestProperty("Connection", "Keep-Alive"); 
    con.setRequestProperty("Charset", "UTF-8"); 
    con.setRequestProperty("Content-Type", 
      "multipart/form-data;boundary=" + boundary); 
 
    outputStream = new DataOutputStream( 
      con.getOutputStream()); 
    outputStream.writeBytes(mTwoHyphens + boundary + mLineEnd); 
    outputStream.writeBytes("Content-Disposition: form-data; name=\"file\"; filename=\"" + fileName + "\"" + mLineEnd); 
    outputStream.writeBytes("Content-Type:application/octet-stream \r\n"); 
    outputStream.writeBytes(mLineEnd); 
 
    mbytesAvailable = fileInputStream.available(); 
    mBufferSize = Math.min(mbytesAvailable, maxBufferSize); 
    buffer = new byte[mBufferSize]; 
 
    // Read file 
    mBytesRead = fileInputStream.read(buffer, 0, mBufferSize); 
 
    while (mBytesRead > 0) { 
     outputStream.write(buffer, 0, mBufferSize); 
     length += mBufferSize; 
 
     publishProgress((int) ((length * 100) / mTtotalSize)); 
 
     mbytesAvailable = fileInputStream.available(); 
 
     mBufferSize = Math.min(mbytesAvailable, maxBufferSize); 
 
     mBytesRead = fileInputStream.read(buffer, 0, mBufferSize); 
    } 
    outputStream.writeBytes(mLineEnd); 
    outputStream.writeBytes(mTwoHyphens + boundary + mTwoHyphens 
      + mLineEnd); 
    publishProgress(100); 
 
    // Responses from the server (code and message) 
    int serverRespOnseCode= con.getResponseCode(); 
    String serverRespOnseMessage= con.getResponseMessage(); 
    fileInputStream.close(); 
    outputStream.flush(); 
    outputStream.close(); 
 
   } catch (Exception ex) { 
    ex.printStackTrace(); 
    Log.v(TAG,"uploadError"); 
   } 
   return null; 
  } 
 
  @Override 
  protected void onProgressUpdate(Integer... progress) { 
   mPgBar.setProgress(progress[0]); 
  } 
 } 

主要流程为继承AsyncTask,然后使用HttpURLConnection 去上传文件。代码比较简单,就不一一讲解了。
其中要注意的是需要在

代码如下:
outputStream.writeBytes("Content-Disposition: form-data; name=\"file\"; filename=\"" +  fileName + "\"" + mLineEnd); 

将name 设置为web 请求的参数名,由于我的服务端是将文件设置为file参数,所以我可以直接填file .所以大家可以根据实际情况作相应修改。

那么接着上服务端代码,服务端主要使用status 2框架作请求。那么我们就需要进行封装。

//上传文件集合 
 private List file; 
 //上传文件名集合 
 private List fileFileName; 
 //上传文件内容类型集合 
 private List fileContentType; 
 
 public List getFile() { 
  return file; 
 } 
 
 public void setFile(List file) { 
  this.file = file; 
 } 
 
 public List getFileFileName() { 
  return fileFileName; 
 } 
 
 public void setFileFileName(List fileFileName) { 
  this.fileFileName = fileFileName; 
 } 
 
 public List getFileContentType() { 
  return fileContentType; 
 } 
 
 public void setFileContentType(List fileContentType) { 
  this.fileCOntentType= fileContentType; 
 } 

采用了多文件上传的方法,定义了List 集合。
那么处理文件上传的action ,由于是测试方法。这里就定义为testUpload

public String testUpload()throws Exception{ 
  System.out.println("success"); 
  uploadFile(0); 
  return SUCCESS; 
 } 

到这里就已经才不多完成动作了,现在需要开始写上传的方法 uploadFile(int index),由于定义file 为多文件上传,而我们上传只上传了一个文件,所以这里参数为0

/** 
  * 上传功能 
  * @param i 
  * @return 
  * @throws FileNotFoundException 
  * @throws IOException 
  */ 
 private String uploadFile(int i) throws FileNotFoundException, IOException { 
   
  try { 
   InputStream in = new FileInputStream(file.get(i)); 
 
   //String dir = ServletActionContext.getRequest().getRealPath(UPLOADDIR); 
    
   String dir = "D://UploadData/"; 
 
   File uploadFile = new File(dir,StringUtils.getUUID()+getFile( this.getFileFileName().get(i))); 
 
   OutputStream out = new FileOutputStream(uploadFile); 
 
   byte[] buffer = new byte[1024 * 1024]; 
 
   int length; 
   while ((length = in.read(buffer)) > 0) { 
    out.write(buffer, 0, length); 
   } 
 
   in.close(); 
   out.close(); 
   //然后进行计算 
   return uploadFile.getAbsolutePath(); 
  } catch (FileNotFoundException ex) { 
   ex.printStackTrace(); 
  } catch (IOException ex) { 
   ex.printStackTrace(); 
  } 
  return null; 
 } 

上面方法为将缓存区域的文件 然后搞到了D://UploadData/ 文件中,然后以自己的格式进行命名,这里我使用了电脑的UUID和文件名进行组合,确保我复制过来的文件不重复。
最后上传成功之后返回文件的真实地址。

ok,写到这里上传文件的功能基本上做完了。最后只剩下配置action 动作。

ok,我们打开status.xml 文件进行配置

 
  
  
  
  

这里主要定义上传文件的临时存放位置,然后大小限制。
大家可以根据实际情况进行配置。

最后上传一张效果图。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


推荐阅读
  • Android 九宫格布局详解及实现:人人网应用示例
    本文深入探讨了人人网Android应用中独特的九宫格布局设计,解析其背后的GridView实现原理,并提供详细的代码示例。这种布局方式不仅美观大方,而且在现代Android应用中较为少见,值得开发者借鉴。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • Android LED 数字字体的应用与实现
    本文介绍了一种适用于 Android 应用的 LED 数字字体(digital font),并详细描述了其在 UI 设计中的应用场景及其实现方法。这种字体常用于视频、广告倒计时等场景,能够增强视觉效果。 ... [详细]
  • RecyclerView初步学习(一)
    RecyclerView初步学习(一)ReCyclerView提供了一种插件式的编程模式,除了提供ViewHolder缓存模式,还可以自定义动画,分割符,布局样式,相比于传统的ListVi ... [详细]
  • QUIC协议:快速UDP互联网连接
    QUIC(Quick UDP Internet Connections)是谷歌开发的一种旨在提高网络性能和安全性的传输层协议。它基于UDP,并结合了TLS级别的安全性,提供了更高效、更可靠的互联网通信方式。 ... [详细]
  • 本文探讨了 RESTful API 和传统接口之间的关键差异,解释了为什么 RESTful API 在设计和实现上具有独特的优势。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • Python自动化处理:从Word文档提取内容并生成带水印的PDF
    本文介绍如何利用Python实现从特定网站下载Word文档,去除水印并添加自定义水印,最终将文档转换为PDF格式。该方法适用于批量处理和自动化需求。 ... [详细]
  • 在当前众多持久层框架中,MyBatis(前身为iBatis)凭借其轻量级、易用性和对SQL的直接支持,成为许多开发者的首选。本文将详细探讨MyBatis的核心概念、设计理念及其优势。 ... [详细]
  • 将Web服务部署到Tomcat
    本文介绍了如何在JDeveloper 12c中创建一个Java项目,并将其打包为Web服务,然后部署到Tomcat服务器。内容涵盖从项目创建、编写Web服务代码、配置相关XML文件到最终的本地部署和验证。 ... [详细]
  • XNA 3.0 游戏编程:从 XML 文件加载数据
    本文介绍如何在 XNA 3.0 游戏项目中从 XML 文件加载数据。我们将探讨如何将 XML 数据序列化为二进制文件,并通过内容管道加载到游戏中。此外,还会涉及自定义类型读取器和写入器的实现。 ... [详细]
  • 本文介绍如何在 Unity 的 XML 配置文件中,将参数传递给自定义生命周期管理器的构造函数。我们将详细探讨 CustomLifetimeManager 类的实现及其配置方法。 ... [详细]
  • 本文详细介绍了 Java 中 org.apache.xmlbeans.SchemaType 类的 getBaseEnumType() 方法,提供了多个代码示例,并解释了其在不同场景下的使用方法。 ... [详细]
  • 本文详细介绍了如何解决MyBatis中常见的BindingException错误,提供了多种排查和修复方法,确保Mapper接口与XML文件的正确配置。 ... [详细]
  • 基于KVM的SRIOV直通配置及性能测试
    SRIOV介绍、VF直通配置,以及包转发率性能测试小慢哥的原创文章,欢迎转载目录?1.SRIOV介绍?2.环境说明?3.开启SRIOV?4.生成VF?5.VF ... [详细]
author-avatar
大眼妹886
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有