package uploadDemo;

import java.io.DataOutputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.net.HttpURLConnection;
import java.net.MalformedURLException;
import java.net.URL;
import java.util.UUID;

import android.util.Log;

/**
*
* 上传工具类
* @author spring sky
*/
public class UploadUtil {
private static final String TAG = "uploadFile";
private static final int TIME_OUT = 10*1000; //超时时间
private static final String CHARSET = "utf-8"; //设置编码
/**
* android上传文件到服务器
* @param file 需要上传的文件
* @param RequestURL 请求的rul
* @return 返回响应的内容
*/
public String uploadFile(File file,String RequestURL)
{
String result = null;
String BOUNDARY = UUID.randomUUID().toString(); //边界标识 随机生成
String PREFIX = "--" , LINE_END = "\r\n";
String CONTENT_TYPE = "multipart/form-data"; //内容类型

try {
URL url = new URL(RequestURL);
HttpURLConnection conn = (HttpURLConnection) url.openConnection();
conn.setReadTimeout(TIME_OUT);
conn.setConnectTimeout(TIME_OUT);
conn.setDoInput(true); //允许输入流
conn.setDoOutput(true); //允许输出流
conn.setUseCaches(false); //不允许使用缓存
conn.setRequestMethod("POST"); //请求方式
conn.setRequestProperty("Charset", CHARSET); //设置编码
conn.setRequestProperty("connection", "keep-alive");
conn.setRequestProperty("Content-Type", CONTENT_TYPE + ";boundary=" + BOUNDARY);

if(file!=null)
{
/**
* 当文件不为空,把文件包装并且上传
*/
DataOutputStream dos = new DataOutputStream( conn.getOutputStream());
StringBuffer sb = new StringBuffer();
sb.append(PREFIX);
sb.append(BOUNDARY);
sb.append(LINE_END);
/**
* 这里重点注意:
* name里面的值为服务器端需要key 只有这个key 才可以得到对应的文件
* filename是文件的名字,包含后缀名的 比如:abc.png
*/

sb.append("Content-Disposition: form-data; name=\"img\"; filename=\""+file.getName()+"\""+LINE_END);
sb.append("Content-Type: application/octet-stream; charset="+CHARSET+LINE_END);
sb.append(LINE_END);
dos.write(sb.toString().getBytes());
InputStream is = new FileInputStream(file);
byte[] bytes = new byte[1024];
int len = 0;
while((len=is.read(bytes))!=-1)
{
dos.write(bytes, 0, len);
}
is.close();
dos.write(LINE_END.getBytes());
byte[] end_data = (PREFIX+BOUNDARY+PREFIX+LINE_END).getBytes();
dos.write(end_data);
dos.flush();
/**
* 获取响应码 200=成功
* 当响应成功,获取响应的流
*/
int res = conn.getResponseCode();
Log.e(TAG, "response code:"+res);
// if(res==200)
// {
Log.e(TAG, "request success");
InputStream input = conn.getInputStream();
StringBuffer sb1= new StringBuffer();
int ss ;
while((ss=input.read())!=-1)
{
sb1.append((char)ss);
}
result = sb1.toString();
Log.e(TAG, "result : "+ result);
// }
// else{
// Log.e(TAG, "request error");
// }
}
} catch (MalformedURLException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
return result;
}
}

package ting.app.openwindow;

import java.io.File;

import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.EditText;
import android.widget.TextView;
import android.widget.Toast;

public class FileUploadActivity extends Activity implements OnClickListener {

protected static final int SUCCESS = 2;
protected static final int FAILD = 3;
protected static int RESULT_LOAD_FILE = 1;
private TextView cancel;
private TextView upload;
private EditText pathView;
private Button buttonLoadImage;
private String requestURL = "http://192.168.191.1:8080/UpFile1/UploadServlet";
private String picturePath;
private View show;

@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_file_upload);
initView();
initData();
}

private Handler mHandler = new Handler(new Handler.Callback() {

@Override
public boolean handleMessage(Message msg) {
switch (msg.what) {

case SUCCESS:
show.setVisibility(View.INVISIBLE);
picturePath = "";
pathView.setText(picturePath);
Toast.makeText(getApplicationContext(), "上传成功!",
Toast.LENGTH_LONG).show();
break;
case FAILD:
show.setVisibility(View.INVISIBLE);
Toast.makeText(getApplicationContext(), "上传失败!",
Toast.LENGTH_LONG).show();
break;
default:
break;
}
return false;
}

});

private void initView() {
cancel = (TextView) findViewById(R.id.cancel);
upload = (TextView) findViewById(R.id.upload);
buttonLoadImage = (Button) findViewById(R.id.buttonLoadPicture);
cancel.setOnClickListener(this);
upload.setOnClickListener(this);
buttonLoadImage.setOnClickListener(this);
show = findViewById(R.id.show);
pathView = (EditText) findViewById(R.id.file_path);
pathView.setKeyListener(null);
}

private void initData() {
picturePath = "";
}

@Override
public void onClick(View v) {
switch (v.getId()) {
case R.id.cancel:
finish();
break;
case R.id.buttonLoadPicture:
Intent intent = new Intent(getApplicationContext(),
FileSelectActivity.class);

startActivityForResult(intent, RESULT_LOAD_FILE);
break;
case R.id.upload:
uploadFile();
break;
default:
break;
}
}

@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
if (requestCode == RESULT_LOAD_FILE && resultCode == RESULT_LOAD_FILE
&& data != null) {
picturePath = data.getStringExtra("path");
pathView.setText(picturePath);
}
}

private void uploadFile() {
show.setVisibility(View.VISIBLE);
new Thread() {
@Override
public void run() {
File file=new File(picturePath);
UploadUtil uploadUtil=new UploadUtil();
uploadUtil.uploadFile(file, requestURL);
Message msg = new Message();

msg.what = SUCCESS;

mHandler.sendMessage(msg);

}
}.start();
}

@Override
protected void onDestroy() {
show.setVisibility(View.INVISIBLE);
super.onDestroy();
}
}

package ting.app.openwindow;

import java.io.File;
import java.util.Arrays;
import java.util.Comparator;

import android.app.ListActivity;
import android.content.Context;
import android.content.Intent;
import android.os.Bundle;
import android.os.Environment;
import android.util.Log;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.ImageView;
import android.widget.ListView;
import android.widget.TextView;
import android.widget.Toast;

public class FileSelectActivity extends ListActivity {
private static final String root = new String(Environment
.getExternalStorageDirectory().getPath() + File.separator);
private TextView tv;// 显示文件的目录
private File[] files;

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_fileupload);
tv = (TextView) findViewById(R.id.currPath);
getFiles(root);
}

public void getFiles(String path) {

tv.setText(path);
File f = new File(path);
// 得到所有子文件和文件夹
File[] tem = f.listFiles();
// 如果当前的目录不是在顶层目录,就把父目录要到files数组中的第一个
if (!path.equals(root)) {
files = new File[tem.length + 1];
System.arraycopy(tem, 0, files, 1, tem.length);
files[0] = f.getParentFile();
} else {
files = tem;
}
Log.e("aaaaaaaaaa", files.toString());
sortFilesByDirectory(files);
// 为ListActivity设置Adapter
setListAdapter(new Adapter(this, files, files.length == tem.length));
}

// 对文件进行排序
private void sortFilesByDirectory(File[] files) {
Arrays.sort(files, new Comparator<File>() {
public int compare(File f1, File f2) {
return Long.valueOf(f1.length()).compareTo(f2.length());
}
});
}

@Override
protected void onListItemClick(ListView l, View v, int position, long id) {
File f = files[position];
if (!f.canRead()) {
Toast.makeText(this, "文件不可读", Toast.LENGTH_SHORT).show();
return;
}
if (f.isFile()) {// 为文件
String path = f.getAbsolutePath();
Intent intent = new Intent();
intent.putExtra("path", path);
setResult(FileUploadActivity.RESULT_LOAD_FILE, intent);
finish();
} else {
getFiles(f.getAbsolutePath());
}
}

class Adapter extends BaseAdapter {
private File[] files;
private boolean istop;
private Context context;

public Adapter(Context context, File[] files, boolean istop) {
this.context = context;
this.files = files;
this.istop = istop;
}

@Override
public int getCount() {
return files.length;
}

@Override
public Object getItem(int position) {
return files[position];
}

@Override
public long getItemId(int position) {
return position;
}

@Override
public View getView(int position, View convertView, ViewGroup parent) {
Holder holder = null;
if (convertView == null) {
holder = new Holder();
convertView = View.inflate(context, R.layout.item_fileupload,
null);
holder.iv = (ImageView) convertView
.findViewById(R.id.adapter_icon);
holder.tv = (TextView) convertView
.findViewById(R.id.adapter_txt);
convertView.setTag(holder);
} else {
holder = (Holder) convertView.getTag();
}
// 设置convertView中控件的值
setconvertViewRow(position, holder);
return convertView;
}

private void setconvertViewRow(int position, Holder holder) {
File f = files[position];
holder.tv.setText(f.getName());
if (!istop && position == 0) {// 不是在顶层目录
// 加载后退图标
holder.iv.setImageResource(R.drawable.back_up);
} else if (f.isFile()) {// 是文件
// 加载文件图标
holder.iv.setImageResource(R.drawable.file);
} else {// 文件夹
// 加载文件夹图标
holder.iv.setImageResource(R.drawable.dir);
}
}

class Holder {
private ImageView iv;
private TextView tv;
}
}
}

android文件上传到服务器的更多相关文章

  1. Android -- 文件上传到服务器

    1. 文件上传的两种方式 (1) HttpClient (2)AsyncHttpClient (开源框架: https://github.com/loopj/android-async-http) 示 ...

  2. Java实现文件上传到服务器(FTP方式)

    Java实现文件上传到服务器(FTP方式) 1,jar包:commons-net-3.3.jar 2,实现代码: //FTP传输到数据库服务器 private boolean uploadServer ...

  3. Linux 文件上传Linux服务器

    进入命令行 在图形化桌面出现之前,与Unix系统进行交互的唯一方式就是借助由shell所提供的文本命令行界面(command line interface,CLI).CLI只能接受文本输入,也只能显示 ...

  4. 基于paramiko将文件上传到服务器上

    通过安装使用paramiko模块,将本地文件上传到服务器上 import paramiko import datetime import os hostname = '服务器ip' username ...

  5. ubuntu中将本地文件上传到服务器

    (1)在本地的终端下,而不是在服务器上.在本地的终端上才能将本地的文件拷入服务器. (2) scp -r localfile.txt username@192.168.0.1:/home/userna ...

  6. 一、手把手教你docker搭建fastDFS文件上传下载服务器

    在搭建fastDFS文件上传下载服务器之前,你需要准备的有一个可连接的linux服务器,并且该linux服务器上已经安装了docker,若还有没安装docker的,先百度自行安装docker. 1.执 ...

  7. android和struts2实现android文件上传

    1.开发准备如下2个工具类 package org.lxh.util; import java.io.BufferedReader; import java.io.InputStreamReader; ...

  8. Android文件上传与下载

    文件上传与下载 文件上传 -- 服务端 以Tomcat为服务器,Android客服端访问Servlet,经Servlet处理逻辑,最终将文件上传,这里就是简单模拟该功能,就将文件上传到本机的D:\\u ...

  9. java文件上传到服务器

    最近项目中使用到了文件从本地到服务器的功能.其实是为了解决目前浏览器不支持获取本地文件全路径.不得已而想到上传到服务器的固定目录,从而方便项目获取文件,进而使程序支持EXCEL批量导入数据. 在前台界 ...

随机推荐

  1. JVM 运行时数据区域

    Java虚拟机管理的内存包括以下几个运行时数据区域: 1.程序计数器: 程序计数器是一块比较小的内存空间,是当前线程执行的字节码行号指示器.Java多线程是通过线程轮流切换来实现的,所以每个线程都有一 ...

  2. gnuplot 学习笔记

    1 如何运行 gnuplot是一个命令行输入的工具,把命令行写入一个文本file1 file2.使用下列方式运行. gnuplot {option} file1 file2 2 产生一个图标,不管数据 ...

  3. Java基本运算符

    1.算术运算符 作用是数字的计算,包括:正号+,负号-,乘*,除/,余%,加+,减-,其算法与数学中的运算相同. 算术运算符实例(假设变量A=10,变量B=20): 操作符 描述 例子 + 正号 +A ...

  4. UESTC 912 树上的距离 --LCA+RMQ+树状数组

    1.易知,树上两点的距离dis[u][v] = D[u]+D[v]-2*D[lca(u,v)] (D为节点到根节点的距离) 2.某条边<u,v>权值一旦改变,将会影响所有以v为根的子树上的 ...

  5. HDU 3584 Cube --三维树状数组

    题意:给一个三维数组n*n*n,初始都为0,每次有两个操作: 1. 翻转(x1,y1,z1) -> (x2,y2,z2) 0. 查询A[x][y][z] (A为该数组) 解法:树状数组维护操作次 ...

  6. IO流的练习1 —— 随机获取文本中的信息

    需求:一个文本中有几个名字,随机从中获取一个名字 分析: A:首先把文本中的数据读出 B:再把数据存储到集合中 C:产生一个随机的索引 D:打印出这个索引对应的值 public static void ...

  7. HTML5 web workes实现多线程

    对多线程来说尽量使用HTML5的WEB WORKER特性 HTML5中的Web Worker是使用多个线程并发执行Javascript程序.另外,这种特别的多线程实现能减少困惑开发者多年的,在其他平台 ...

  8. flex布局滑动页面

    html: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF ...

  9. VFS分析(一)挂载(持续更新)

    基础知识在<深入linux内核架构>第8章,自行脑补. 看下几个关键的过程: do_add_mount里有重要函数lock_mount, lock_mount函数的输入是struct pa ...

  10. Node.js之事件events

    Events a.EventEmitter支持多个事件监听,最大为10,也可以自定义最大数 //添加监听var EventEmitter = require('events').EventEmitte ...