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. java 15-1 Collection集合的概述以及小功能介绍

     集合的由来:  我们学习的是面向对象语言,而面向对象语言对事物的描述是通过对象体现的,为了方便对多个对象进行操作,我们就必须把这多个对象进行存储.  而要想存储多个对象,就不能是一个基本的变量,而应 ...

  2. CSS padding margin border属性

    主要定义四个区域:内容(content).内边距(padding).边框(border)和外边距(margin) margin:层的边框以外留的空白 background-color:背景颜色 bac ...

  3. ABP入门系列——使用ABP集成的邮件系统发送邮件

    ABP中对邮件的封装主要集成在Abp.Net.Mail和Abp.Net.Mail.Smtp命名空间下,相应源码在此. #一.Abp集成的邮件模块是如何实现的 分析可以看出主要由以下几个核心类组成: E ...

  4. 微软职位内部推荐-Principal Development Lead

    微软近期Open的职位: Job Title: Principal Development Lead Work Location: Suzhou, China This is a once in a ...

  5. 微软职位内部推荐-Sr. SW Engineer for Azure Networking

    微软近期Open的职位: Senior SW Engineer The world is moving to cloud computing. Microsoft is betting Windows ...

  6. [资料]pthreads PHP

    1. 参考手册http://php.net/manual/zh/book.pthreads.php 2. windows下安装php真正的多线程扩展pthreads教程http://www.think ...

  7. python数字图像处理(12):基本图形的绘制

    图形包括线条.圆形.椭圆形.多边形等. 在skimage包中,绘制图形用的是draw模块,不要和绘制图像搞混了. 1.画线条 函数调用格式为: skimage.draw.line(r1,c1,r2,c ...

  8. python数字图像处理(10):图像简单滤波

    对图像进行滤波,可以有两种效果:一种是平滑滤波,用来抑制噪声:另一种是微分算子,可以用来检测边缘和特征提取. skimage库中通过filters模块进行滤波操作. 1.sobel算子 sobel算子 ...

  9. jdbc 得到表结构、主键

    jdbc 得到表结构.主键 标签: jdbctablenullschema数据库mysql 2012-02-16 22:13 11889人阅读 评论(0) 收藏 举报  分类: Java(71)  假 ...

  10. Java环境解析apk文件信息

    概述:Java解析apk文件,获取apk文件里的包名,版本号,图标文件等; 功能:可以提供给windows和linux平台使用; 原理:利用aapt.exe或者aapt这些anroid平台解析apk文 ...