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. Sql Practice 2

    之前写了一个SP用来向dimention table插入0 -1 dummy row的值,但今天在process adventureworksdw2008示例 数据库的时候报错,查看了一下,是因为自己 ...

  2. 动手学习TCP:TCP连接建立与终止

    TCP是一个面向连接的协议,任何一方在发送数据之前,都必须先在双方之间建立一条连接.所以,本文就主要看看TCP连接的建立和终止. 在开始介绍TCP连接之前,先来看看TCP数据包的首部,首部里面有很多重 ...

  3. Linux 系统常用命令汇总(七) 安全设置

     安全设置 分类 命令 选项 注解 安全策略 selinux setenforce number(0,1) 设置selinux状态,0关闭,1开启 getenforce 显示当前selinux状态,e ...

  4. NOIP2008 T3 传纸条 解题报告——S.B.S.

    题目描述 小渊和小轩是好朋友也是同班同学,他们在一起总有谈不完的话题.一次素质拓展活动中,班上同学安排做成一个m行n列的矩阵,而小渊和小轩被安排在矩阵对角线的两端,因此,他们就无法直接交谈了.幸运的是 ...

  5. 【读书笔记《Android游戏编程之从零开始》】18.游戏开发基础(碰撞检测)

    1.矩形碰撞 所谓矩形碰撞,就是利用两个矩形之间的位置关系来进行判断,如果矩形的像素在另外一个矩形之中,或者之上都可以认为这两个矩形发生了碰撞. 如果单纯的去考虑哪些情况会判定两个矩形发生碰撞,倒不如 ...

  6. c++实现排序(简单插入,希尔,选择,快速,冒泡,堆排)

    简单插入排序 适用于记录较少且基本有序的记录.算法思想:给定一个存在分界线的序列,分界线左边有序,右边无序,依次将右边的没排序的数与左边序列进行比较,插入相应位置,再对分界线做出相应调整,下面用图来说 ...

  7. uGUI练习(一) Anchor

    一.练习步骤 如果用过NGUI的Anchor,我们知道在2.x的版本有UIAnchor组件(下图左),3.x版本中,每个UIWidget有自带的Anchors(下图右) 而uGUI的Anchor用起来 ...

  8. 每日一语:What is he getting at?

    What is he getting at? 他讲这话是什么意思? 2015-1-12

  9. SQL Server进制

    在项目中,大家可能都遇到过,需要把十进制转换为其他进制的情况,google上一搜,已经有很多2进制.8进制.16进制和十进制的转换方法.但是在一些项目中,这些可能无法满足要求,可能需要17.18甚至是 ...

  10. 转:Android开发实践:用脚本编译Android工程

    转自: http://ticktick.blog.51cto.com/823160/1365947 一般情况下,我们都是使用Eclipse+ADT插件或者Android studio软件来编译Andr ...