Android上传文件到服务器的方法

本文实例为大家分享了Android端实现文件上传的具体代码,供大家参考,具体内容如下

1)、新建一个Android项目命名为androidUpload,目录结构如下:

2)、新建FormFile类,用来封装文件信息

package com.ljq.utils;

import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.InputStream;

/**
 * 上传文件
 */
public class FormFile {
 /* 上传文件的数据 */
 private byte[] data;
 private InputStream inStream;
 private File file;
 /* 文件名称 */
 private String filname;
 /* 请求参数名称*/
 private String parameterName;
 /* 内容类型 */
 private String contentType = "application/octet-stream";

 public FormFile(String filname, byte[] data, String parameterName, String contentType) {
  this.data = data;
  this.filname = filname;
  this.parameterName = parameterName;
  if(contentType!=null) this.contentType = contentType;
 }

 public FormFile(String filname, File file, String parameterName, String contentType) {
  this.filname = filname;
  this.parameterName = parameterName;
  this.file = file;
  try {
   this.inStream = new FileInputStream(file);
  } catch (FileNotFoundException e) {
   e.printStackTrace();
  }
  if(contentType!=null) this.contentType = contentType;
 }

 public File getFile() {
  return file;
 }

 public InputStream getInStream() {
  return inStream;
 }

 public byte[] getData() {
  return data;
 }

 public String getFilname() {
  return filname;
 }

 public void setFilname(String filname) {
  this.filname = filname;
 }

 public String getParameterName() {
  return parameterName;
 }

 public void setParameterName(String parameterName) {
  this.parameterName = parameterName;
 }

 public String getContentType() {
  return contentType;
 }

 public void setContentType(String contentType) {
  this.contentType = contentType;
 }

}

3)、新建SocketHttpRequester类,封装上传文件到服务器代码

package com.ljq.utils;

import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.net.InetAddress;
import java.net.Socket;
import java.net.URL;
import java.util.Map;

/**
 * 上传文件到服务器
 *
 * @author Administrator
 *
 */
public class SocketHttpRequester {
 /**
  * 直接通过HTTP协议提交数据到服务器,实现如下面表单提交功能:
  * <FORM METHOD=POST ACTION="http://192.168.1.101:8083/upload/servlet/UploadServlet" enctype="multipart/form-data">
   <INPUT TYPE="text" NAME="name">
   <INPUT TYPE="text" NAME="id">
   <input type="file" name="imagefile"/>
   <input type="file" name="zip"/>
   </FORM>
  * @param path 上传路径(注:避免使用localhost或127.0.0.1这样的路径测试,因为它会指向手机模拟器,你可以使用http://www.iteye.cn或http://192.168.1.101:8083这样的路径测试)
  * @param params 请求参数 key为参数名,value为参数值
  * @param file 上传文件
  */
 public static boolean post(String path, Map<String, String> params, FormFile[] files) throws Exception{
  final String BOUNDARY = "---------------------------7da2137580612"; //数据分隔线
  final String endline = "--" + BOUNDARY + "--\r\n";//数据结束标志

  int fileDataLength = 0;
  for(FormFile uploadFile : files){//得到文件类型数据的总长度
   StringBuilder fileExplain = new StringBuilder();
    fileExplain.append("--");
    fileExplain.append(BOUNDARY);
    fileExplain.append("\r\n");
    fileExplain.append("Content-Disposition: form-data;name=\""+ uploadFile.getParameterName()+"\";filename=\""+ uploadFile.getFilname() + "\"\r\n");
    fileExplain.append("Content-Type: "+ uploadFile.getContentType()+"\r\n\r\n");
    fileExplain.append("\r\n");
    fileDataLength += fileExplain.length();
   if(uploadFile.getInStream()!=null){
    fileDataLength += uploadFile.getFile().length();
    }else{
     fileDataLength += uploadFile.getData().length;
    }
  }
  StringBuilder textEntity = new StringBuilder();
  for (Map.Entry<String, String> entry : params.entrySet()) {//构造文本类型参数的实体数据
   textEntity.append("--");
   textEntity.append(BOUNDARY);
   textEntity.append("\r\n");
   textEntity.append("Content-Disposition: form-data; name=\""+ entry.getKey() + "\"\r\n\r\n");
   textEntity.append(entry.getValue());
   textEntity.append("\r\n");
  }
  //计算传输给服务器的实体数据总长度
  int dataLength = textEntity.toString().getBytes().length + fileDataLength + endline.getBytes().length;

  URL url = new URL(path);
  int port = url.getPort()==-1 ? 80 : url.getPort();
  Socket socket = new Socket(InetAddress.getByName(url.getHost()), port);
  OutputStream outStream = socket.getOutputStream();
  //下面完成HTTP请求头的发送
  String requestmethod = "POST "+ url.getPath()+" HTTP/1.1\r\n";
  outStream.write(requestmethod.getBytes());
  String accept = "Accept: image/gif, image/jpeg, image/pjpeg, image/pjpeg, application/x-shockwave-flash, application/xaml+xml, application/vnd.ms-xpsdocument, application/x-ms-xbap, application/x-ms-application, application/vnd.ms-excel, application/vnd.ms-powerpoint, application/msword, */*\r\n";
  outStream.write(accept.getBytes());
  String language = "Accept-Language: zh-CN\r\n";
  outStream.write(language.getBytes());
  String contenttype = "Content-Type: multipart/form-data; boundary="+ BOUNDARY+ "\r\n";
  outStream.write(contenttype.getBytes());
  String contentlength = "Content-Length: "+ dataLength + "\r\n";
  outStream.write(contentlength.getBytes());
  String alive = "Connection: Keep-Alive\r\n";
  outStream.write(alive.getBytes());
  String host = "Host: "+ url.getHost() +":"+ port +"\r\n";
  outStream.write(host.getBytes());
  //写完HTTP请求头后根据HTTP协议再写一个回车换行
  outStream.write("\r\n".getBytes());
  //把所有文本类型的实体数据发送出来
  outStream.write(textEntity.toString().getBytes());
  //把所有文件类型的实体数据发送出来
  for(FormFile uploadFile : files){
   StringBuilder fileEntity = new StringBuilder();
    fileEntity.append("--");
    fileEntity.append(BOUNDARY);
    fileEntity.append("\r\n");
    fileEntity.append("Content-Disposition: form-data;name=\""+ uploadFile.getParameterName()+"\";filename=\""+ uploadFile.getFilname() + "\"\r\n");
    fileEntity.append("Content-Type: "+ uploadFile.getContentType()+"\r\n\r\n");
    outStream.write(fileEntity.toString().getBytes());
    if(uploadFile.getInStream()!=null){
     byte[] buffer = new byte[1024];
     int len = 0;
     while((len = uploadFile.getInStream().read(buffer, 0, 1024))!=-1){
      outStream.write(buffer, 0, len);
     }
     uploadFile.getInStream().close();
    }else{
     outStream.write(uploadFile.getData(), 0, uploadFile.getData().length);
    }
    outStream.write("\r\n".getBytes());
  }
  //下面发送数据结束标志,表示数据已经结束
  outStream.write(endline.getBytes());

  BufferedReader reader = new BufferedReader(new InputStreamReader(socket.getInputStream()));
  if(reader.readLine().indexOf("200")==-1){//读取web服务器返回的数据,判断请求码是否为200,如果不是200,代表请求失败
   return false;
  }
  outStream.flush();
  outStream.close();
  reader.close();
  socket.close();
  return true;
 }

 /**
  * 提交数据到服务器
  * @param path 上传路径(注:避免使用localhost或127.0.0.1这样的路径测试,因为它会指向手机模拟器,你可以使用http://www.itcast.cn或http://192.168.1.10:8080这样的路径测试)
  * @param params 请求参数 key为参数名,value为参数值
  * @param file 上传文件
  */
 public static boolean post(String path, Map<String, String> params, FormFile file) throws Exception{
  return post(path, params, new FormFile[]{file});
 }
}

4)、新建MainActivity类,实现每隔5秒上传一次

package com.ljq.activity;

import java.io.File;
import java.util.HashMap;
import java.util.Map;

import android.app.Activity;
import android.os.Bundle;
import android.os.Environment;
import android.os.Handler;
import android.util.Log;

import com.ljq.utils.FormFile;
import com.ljq.utils.SocketHttpRequester;

public class MainActivity extends Activity {
 private File file;
 private Handler handler;
 private static final String TAG="MainActivity";

 @Override
 public void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.main);
  Log.i(TAG, "onCreate");

  file = new File(Environment.getExternalStorageDirectory(), "123.rmvb");
  Log.i(TAG, "照片文件是否存在:"+file);
  handler=new Handler();
  handler.post(runnable);
 }

 Runnable runnable=new Runnable() {

  public void run() {
   Log.i(TAG, "runnable run");
   uploadFile(file);
   handler.postDelayed(runnable, 5000);
  }

 };

 /**
  * 上传图片到服务器
  *
  * @param imageFile 包含路径
  */
 public void uploadFile(File imageFile) {
  Log.i(TAG, "upload start");
  try {
   String requestUrl = "http://192.168.1.101:8083/upload/upload/execute.do";
   //请求普通信息
   Map<String, String> params = new HashMap<String, String>();
   params.put("username", "张三");
   params.put("pwd", "zhangsan");
   params.put("age", "21");
   params.put("fileName", imageFile.getName());
   //上传文件
   FormFile formfile = new FormFile(imageFile.getName(), imageFile, "image", "application/octet-stream");

   SocketHttpRequester.post(requestUrl, params, formfile);
   Log.i(TAG, "upload success");
  } catch (Exception e) {
   Log.i(TAG, "upload error");
   e.printStackTrace();
  }
  Log.i(TAG, "upload end");
 }
}

5)、修改清单文件

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
 package="com.ljq.activity"
 android:versionCode="1"
 android:versionName="1.0">
 <application android:icon="@drawable/icon" android:label="@string/app_name">
 <activity android:name=".MainActivity"
  android:label="@string/app_name">
 <intent-filter>
 <action android:name="android.intent.action.MAIN" />
 <category android:name="android.intent.category.LAUNCHER" />
 </intent-filter>
 </activity>

 </application>
 <uses-sdk android:minSdkVersion="4" />
 <uses-permission android:name="android.permission.INTERNET" /> 

</manifest>

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

时间: 2017-05-31

Android多线程+单线程+断点续传+进度条显示下载功能

效果图 白话分析: 多线程:肯定是多个线程咯 断点:线程停止下载的位置 续传:线程从停止下载的位置上继续下载,直到完成任务为止. 核心分析: 断点: 当前线程已经下载的数据长度 续传: 向服务器请求上次线程停止下载位置的数据 con.setRequestProperty("Range", "bytes=" + start + "-" + end); 分配线程: int currentPartSize = fileSize / mThreadNum

Android微信端的下拉刷新功能

在Android和iOS上对于下拉刷新的处理方法: 在微信公众号内,在面对下拉刷新这个问题上,Android和iOS都自己的表现方式: iOS: Android: 所以我们要给内容加载监听器 function bindEvent() { document.addEventListener('touchstart', touchSatrtFunc, false); document.addEventListener('touchmove', touchMoveFunc, false); docum

Android扫描二维码时出现用户禁止权限报错问题解决办法

Android扫描二维码时出现用户禁止权限报错问题解决办法 当我用ZBarDecoder.jar写了一个扫描二维码的程序,确实实现了扫描功能.组长说如果用户禁止调用摄像头,那程序也不能崩溃.结果我一运行就崩溃了.在网上自己找了找,可以这样解决. try { mCameraManager.openDriver(); } catch (Exception e) { //当用户手动禁止摄像头权限时,防止系统崩溃 AlertDialog.Builder builder=new AlertDialog.B

Android Studio中使用lambda表达式的方法

1.module的build.gradle里buildTypes中添加: compileOptions { sourceCompatibility JavaVersion.VERSION_1_8 targetCompatibility JavaVersion.VERSION_1_8 } 2.module的build.gradle里defaultConfig中添加: jackOptions.enabled = true 3.注意事项:jack可能会导致中文乱码,所以需要在gradle.proper

Android RecyclerView仿新闻头条的频道管理功能

需要在build里添加依赖 compile 'com.android.support:recyclerview-v7:25.3.1' 布局文件activity_main <android.support.v7.widget.RecyclerView android:layout_weight="1" android:id="@+id/recyclerView_up" android:layout_width="match_parent" a

Android 监听应用前/后台切换实例代码

前言 这周接到一个需求,需要在应用从后台切换到前台时,展示我们的广告.展示页面其实可以复用以前的开屏广告页,唯一的问题就是如何监听应用从后台切到了前台. 正文 在众多方法中,我采用了以下这种方式.废话不多说,咱们直接看代码: //自定义Application类 public class MyApplication extends Application 在清单文件中声明 <application android:name=".MyApplication" android:allo

Kotlin编写Android适配器Adapter

说好今天要写一个使用Kotlin写Adapter的列子,我想了半天也没有组织好语言,直接上代码吧,有一定Android基础的小伙伴肯定是能看的懂的 package com.example.administrator.kotlintest import android.content.Context import android.view.LayoutInflater import android.view.View import android.view.ViewGroup import and

Android 判断ip地址合法实现代码

Android 判断ip地址合法实现代码 昨天,我在网上找了一下判断文本框内的字符串是否是合法的ip地址,自己想到了正则表达式,可是自己对这个却不熟,所以在网上查找了一些资料,最后终于是做出来了. 具体的代码很简单, public boolean isIP(String addr) { if(addr.length() < 7 || addr.length() > 15 || "".equals(addr)) { return false; } /** * 判断IP格式和范

js判断非127开头的IP地址的实例代码

js验证回送地址,IP地址不能以127开头 回送地址(127.x.x.x)是本机回送地址(Loopback Address) var ipNotStartWith127 = function(ip) { try { var data = ip.split("."), ip1; return 4 == data.length && 127 !== parseInt(data[0]) } catch (e) { return !1 } } console.log(ipNot

Android 获取IP地址的实现方法

Android 获取IP地址 最近做项目,有一个需求是Android设备获取当前IP的功能,经过一番查询资料解决了,记录下实现方法. 1.使用WIFI 首先设置用户权限 <uses-permission Android:name="android.permission.ACCESS_WIFI_STATE"></uses-permission> <uses-permission android:name="android.permission.CH

Java判断IP地址为内网IP还是公网IP的方法

本文实例讲述了Java判断IP地址为内网IP还是公网IP的方法.分享给大家供大家参考.具体分析如下: tcp/ip协议中,专门保留了三个IP地址区域作为私有地址,其地址范围如下: 10.0.0.0/8:10.0.0.0-10.255.255.255 172.16.0.0/12:172.16.0.0-172.31.255.255 192.168.0.0/16:192.168.0.0-192.168.255.255 那么,直接上代码吧: 复制代码 代码如下: public static boolea

asp.net 获取客户端浏览器访问的IP地址的实例代码

本文介绍了asp.net 获取客户端浏览器访问的IP地址的实例代码,分享给大家,自己也留个笔记 1.js方法 <!DOCTYPE html> <html> <head> <meta charset="UTF-8" /> <title>Document</title> <script src="http://pv.sohu.com/cityjson?ie=utf-8"></scr

Java 判断IP地址的合法性实例详解

Java 判断IP地址的合法性 0.前言 有时候我们要对用户输入的IP地址进行校验,判断这个IP地址是不是一个合法的IP地址. 1.实现思路 最简单的实现方法是构造一个正则表达式.判断用户的输入与正则表达式是否匹配.若匹配则是正确的IP地址,否则不是正确的IP地址.这里的难点是如何构造出一个可用的正则表达式. 2.Java实现 /** * Created by HUPENG on 2016/9/26. */ public class Tool { /** * 判断IP地址的合法性,这里采用了正则

java正则表达式判断 ip 地址是否正确解析

这篇文章主要介绍了java正则表达式判断 ip 地址是否正确解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 代码如下 public class ClassWork05 { public static void main(String[] args) { System.out.println(IsIp.isIp("10.10.1.1")); } } class IsIp{ public static boolean isIp(Str

php判断IP地址是否在多个IP段内

本文实例为大家分享了php判断IP地址是否在多个IP段内的具体代码,供大家参考,具体内容如下 IP.class.php <?php class Ip { /** * 取IP * @return string */ public static function get() { if ($_SERVER['HTTP_CLIENT_IP'] && $_SERVER['HTTP_CLIENT_IP']!='unknown') { $ip = $_SERVER['HTTP_CLIENT_IP'

Android实现IP地址输入框的方法示例代码

前言 本文主要给大家介绍了关于Android实现IP地址格式输入框的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧. 实现效果图: 解决方案: 1.添加4个EditText和三个TextView 2.设置TextView内容为点,且靠下方.设置EditText背景和边框为透明 3.为每个EditText添加监听事件 示例代码 Layout: <LinearLayout android:layout_width="match_parent" android

Shell脚本实现判断IP地址是否在一个ip段内代码分享

cat ipcalc.sh #!/bin/bash IP=$1 if [ -z $IP ] then echo -e "\e[31;42m sh ipcalc.sh IP \e[0m" exit fi while read MASK do min=`/usr/bin/ipcalc $MASK|awk '/HostMin:/{print $2}'` max=`/usr/bin/ipcalc $MASK|awk '/HostMax:/{print $2}'` MIN=`echo $min|