上传图片/文件到server
package yao.camera.util;
import java.io.ByteArrayOutputStream;
import java.io.DataOutputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.InputStream;
import java.net.HttpURLConnection;
import java.net.URL;
import android.graphics.Bitmap;
import android.text.TextUtils;
/**
* @author wuxifu 图片/文件的上传: Content-Type: multipart/form-data;
* boundary=---------------------------114556938680 Content-Length: 210
*
* -----------------------------114556938680 Content-Disposition:
* form-data; name="fileName"; filename="wuxifu.txt" Content-Type:
* text/plain
*
* hello how doyou do -----------------------------114556938680--
*
*
*/
public class UploadUtils {
public static final String IMAGE_TYPE_PNG = "PNG";
public static final String IMAGE_TYPE_JPG = "JPG";
public static final String end = "\r\n";
public static final String twoHyphens = "--";
public static final String boundary = "*****";
private String url;
private String fileNameKey;
/**
* @param url
* @param fileNameKey
* name="fileName"之fileName即为fileNameKey,这个取决于后台开发人员的习惯)<form
* action="uploadFile.php" method="post"
* enctype="multipart/form-data"> <input type="file"
* name="fileName"> <input type="submit" value="上传文件"> </form>
*
*/
public UploadUtils(String url, String fileNameKey) {
super();
this.url = url;
this.fileNameKey = fileNameKey;
}
/**
* @param bitmap
* @param imageType PNG JPG
* @param mFileName hello.jpg hello.png 须要扩展名
* @param iUpload
*/
public synchronized void uploadBitmap(Bitmap bitmap, String imageType,String mFileName ,IUpload iUpload) {
try {
URL url2 = new URL(url);
HttpURLConnection con = (HttpURLConnection) url2.openConnection();
/* 同意Input、Output,不使用Cache */
con.setDoInput(true);
con.setDoOutput(true);
con.setUseCaches(false);
/* POST方法 */
con.setRequestMethod("POST");
/* setRequestProperty */
con.setRequestProperty("Connection", "Keep-Alive");
con.setRequestProperty("Charset", "UTF-8");
con.setRequestProperty("Content-Type",
"multipart/form-data;boundary=" + boundary);
DataOutputStream ds = new DataOutputStream(con.getOutputStream());
ds.writeBytes(twoHyphens + boundary + end);
ds.writeBytes("Content-Disposition: form-data; " + "name=\""
+ fileNameKey + "\";filename=\"" + mFileName + "\"");
ds.writeBytes(end);// 换行
// 图片类型的确定
if (!TextUtils.isEmpty(imageType)
&& imageType.equals(IMAGE_TYPE_PNG)) {
ds.writeBytes("Content-Type:image/png");
} else {
ds.writeBytes("Content-Type:image/jpeg");
}
ds.writeBytes(end + end);
ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
// 压缩类型的确定
if (!TextUtils.isEmpty(imageType)
&& imageType.equals(IMAGE_TYPE_PNG)) {
bitmap.compress(Bitmap.CompressFormat.PNG, 100,
byteArrayOutputStream);
} else {
bitmap.compress(Bitmap.CompressFormat.JPEG, 100,
byteArrayOutputStream);
}
byte[] byteArray = byteArrayOutputStream.toByteArray();
ds.write(byteArray);
ds.writeBytes(end + end);
ds.writeBytes(twoHyphens + boundary + twoHyphens + end);
/* close streams */
byteArrayOutputStream.close();
ds.flush();
/* 获取提交数据后server返回的内容 */
InputStream is = con.getInputStream();
StringBuffer b = new StringBuffer();
int length = 0;
byte[] buffer = new byte[1024];
while ((length = is.read(buffer)) != -1) {
b.append(new String(buffer, 0, length));
}
/* success */
iUpload.uploadSuccess(b.toString());
/* close */
ds.close();
} catch (Exception e) {
iUpload.uploadFailed(e.toString());
}
}
/**
* @param file 上传文件
* @param iUpload
*/
public synchronized void uploadFile(File file, IUpload iUpload) {
try {
URL url2 = new URL(url);
HttpURLConnection con = (HttpURLConnection) url2.openConnection();
/* 同意Input、Output,不使用Cache */
con.setDoInput(true);
con.setDoOutput(true);
con.setUseCaches(false);
/* post方法*/
con.setRequestMethod("POST");
/* setRequestProperty */
con.setRequestProperty("Connection", "Keep-Alive");
con.setRequestProperty("Charset", "UTF-8");
con.setRequestProperty("Content-Type",
"multipart/form-data;boundary=" + boundary);
DataOutputStream ds = new DataOutputStream(con.getOutputStream());
ds.writeBytes(twoHyphens + boundary + end);
ds.writeBytes("Content-Disposition: form-data; " + "name=\""
+ fileNameKey + "\";filename=\"" + file.getName() + "\"");
ds.writeBytes(end+end);
FileInputStream fStream = new FileInputStream(file);
int bufferSize = 1024;
byte[] buffer = new byte[bufferSize];
int length = -1;
while ((length = fStream.read(buffer)) != -1) {
ds.write(buffer, 0, length);
ds.flush();
}
ds.writeBytes(end + end);
ds.writeBytes(twoHyphens + boundary + twoHyphens + end);
/* close streams */
fStream.close();
ds.flush();
/* 获取提交数据后server返回的内容*/
InputStream is = con.getInputStream();
StringBuffer b = new StringBuffer();
while ((length = is.read(buffer)) != -1) {
b.append(new String(buffer, 0, length));
}
/* success */
iUpload.uploadSuccess(b.toString());
/*close */
ds.close();
} catch (Exception e) {
iUpload.uploadFailed(e.toString());
}
}
public interface IUpload {
void uploadSuccess(String message);
void uploadFailed(String message);
}
}
上传图片/文件到server的更多相关文章
- [Ajax] 使用Ajax异步上传图片文件(非Form表单提交)
通过表单Form提交来上传文件的方式这里就不说了: 下面介绍,通过js中使用ajax异步上传图片文件: 新建一个html页面和一个一般处理程序即可: 涉及思路: //发送2次Ajax请求完成js异步上 ...
- 利用webuploader插件上传图片文件,完整前端示例demo,服务端使用SpringMVC接收
利用WebUploader插件上传图片文件完整前端示例demo,服务端使用SpringMVC接收 Webuploader简介 WebUploader是由Baidu WebFE(FEX)团队开发的一 ...
- php上传图片文件常用的几个方法
1. 前台 <form class="add-form" method="post" action="/person/save" en ...
- 利用Spring MVC 上传图片文件
本文转自:http://amcucn.iteye.com/blog/264457.感谢作者 近日在工作当中,需要用到上传图片的功能,然而自己平时学习的时候只会使用struts的上传功能,但因为项目并没 ...
- html+php上传图片文件到服务器
html+php上传图片文件到服务器 一.html代码 <body> <form action="" method="post" enctyp ...
- 工作笔记4.struts2上传文件到server
本文介绍两种:上传文件到server的方式 一种是提交Form表单:还有一种是ajaxfileupload异步上传. 一.JSP中: 1.提交Form表单 为了能完毕文件上传,我们应该将这 ...
- Android端通过HttpURLConnection上传文件到server
Android端通过HttpURLConnection上传文件到server 一:实现原理 近期在做Androidclient的应用开发,涉及到要把图片上传到后台server中.自己选择了做Sprin ...
- ajax上传图片文件
这里用的是一个隐藏的iframe,这样可以让form表单提交到这个iframe里面,用户就看不到页面的刷新了 前段时间在解决ajax上传文件时折腾了好一阵.直接用$.post上传文本信息肯定是没有问题 ...
- ionic新手教程第三课-在项目中使用requirejs分离controller文件和server文件
继上篇教程中提到的,我们新建一个简单的tabs类型的Ionic项目. 依据文件夹文件我们知道,系统自己主动创建了一个controller文件和server文件,而且把全部的控制器和服务都写到这两个文件 ...
随机推荐
- 解决前端工程师与UI设计协同工作的问题
前端工程师与UI设计协同工作主要环节在于设计图与前端界面是否一致.(还原度) 不得不说,设计图与前端界面实现不一致的问题时有发生.(好吧,我经验有限)所以经常写完的前端页面都需要去修改.(特别是做移动 ...
- linux随笔三
1.ps 结果输出: PID TTY TIME CMD pts/ :: bash pts/ :: ps显示了程序的进程ID,其运行的终端和进程使用的cpu时间
- TensorFlow——深入MNIST
程序(有些不甚明白的地方改日修订): # _*_coding:utf-8_*_ import inputdata mnist = inputdata.read_data_sets('MNIST_dat ...
- AtCoder Beginner Contest 070
我好想有点思维江化,所以我想给这个丝毫没有问题的abc也写下 A - Palindromic Number Time Limit: 2 sec / Memory Limit: 256 MB Score ...
- JDBC 学习笔记(七)—— CallableStatement
在大型关系型数据库中,有一组为了完成特定功能的 SQL 语句集被称为存储过程(Stored Procedure),它是数据库中的对象. JDBC 使用 CallableStatement 对象,完成对 ...
- 【bzoj2346】[Baltic 2011]Lamp 堆优化Dijkstra
题目描述 2255是一个傻X,他连自己家灯不亮了都不知道.某天TZ大神路过他家,发现了这一情况,于是TZ开始行侠仗义了.TZ发现是电路板的问题,他打开了电路板,发现线路根本没有连上!!于是他强大的脑力 ...
- [luoguP3302] [SDOI2013]森林(主席树 + 启发式合并 + lca)
传送门 显然树上第k大直接主席树 如果连边的话,我们重构小的那一棵,连到另一棵上. 说起来简单,调了我一晚上. 总的来说3个错误: 1.离散化写错位置写到了后面 2."="写成了& ...
- 内存分配(new/delete,malloc/free,allocator,内存池)
以下来源http://www.cnblogs.com/JCSU/articles/1051826.html 程序员们经常编写内存管理程序,往往提心吊胆.如果不想触雷,唯一的解决办法就是发现所有潜伏的地 ...
- css的部分应用示例
CSS :层叠样式表,Cascading Style Sheets.CSS不仅可以静态地修饰网页,还可以配合各种脚本语言动态地对网页各元素进行格式化. 1 vertical-align 在图片与文字对 ...
- python 序列化之pickle模块 json模块
一 pickle import pickle s='dd' print(pickle.dumps(s)) 输出: b'\x80\x03X\x02\x00\x00\x00ddq\x00.' pickle ...