摘抄 ander图片上传
公告:CSDN新版首页上线 欢迎关注CSDN产品客服微博 CSDN论坛 第4期专家问答——基于openstac的可扩展云平台开发
Android模拟 HTTP multipart/form-data 请求协议信息实现图片上传
问题:
Android应用中,当遇到填写用户信息、发表评论等操作,不可避免会遇到“form表单操作”(类似web form操作)上传图片的功能。
在这种情况下,使用Android的HTTPConnection/ ApacheHTTP 通过POST 和GET的方式就实现不了。
解决方法:
Android客户端通过模拟 HTTP multipart/form-data 请求协议信息实现图片上传。
- /**
- * 文件名称:UploadImage.java
- *
- * 版权信息:Apache License, Version 2.0
- *
- * 功能描述:实现图片文件上传。
- *
- * 创建日期:2011-5-10
- *
- * 作者:Bert Lee
- */
- /*
- * 修改历史:
- */
- publicclass UploadImage {
- String multipart_form_data = "multipart/form-data";
- String twoHyphens = "--";
- String boundary = "****************fD4fH3gL0hK7aI6"; // 数据分隔符
- String lineEnd = System.getProperty("line.separator"); // The value is "\r\n" in Windows.
- /*
- * 上传图片内容,格式请参考HTTP 协议格式。
- * 人人网Photos.upload中的”程序调用“http://wiki.dev.renren.com/wiki/Photos.upload#.E7.A8.8B.E5.BA.8F.E8.B0.83.E7.94.A8
- * 对其格式解释的非常清晰。
- * 格式如下所示:
- * --****************fD4fH3hK7aI6
- * Content-Disposition: form-data; name="upload_file"; filename="apple.jpg"
- * Content-Type: image/jpeg
- *
- * 这儿是文件的内容,二进制流的形式
- */
- privatevoid addImageContent(Image[] files, DataOutputStream output) {
- for(Image file : files) {
- StringBuilder split = new StringBuilder();
- split.append(twoHyphens + boundary + lineEnd);
- split.append("Content-Disposition: form-data; name=\"" + file.getFormName() + "\"; filename=\"" + file.getFileName() + "\"" + lineEnd);
- split.append("Content-Type: " + file.getContentType() + lineEnd);
- split.append(lineEnd);
- try {
- // 发送图片数据
- output.writeBytes(split.toString());
- output.write(file.getData(), 0, file.getData().length);
- output.writeBytes(lineEnd);
- } catch (IOException e) {
- thrownew RuntimeException(e);
- }
- }
- }
- /*
- * 构建表单字段内容,格式请参考HTTP 协议格式(用FireBug可以抓取到相关数据)。(以便上传表单相对应的参数值)
- * 格式如下所示:
- * --****************fD4fH3hK7aI6
- * Content-Disposition: form-data; name="action"
- * // 一空行,必须有
- * upload
- */
- privatevoid addFormField(Set<Map.Entry<Object,Object>> params, DataOutputStream output) {
- StringBuilder sb = new StringBuilder();
- for(Map.Entry<Object, Object> param : params) {
- sb.append(twoHyphens + boundary + lineEnd);
- sb.append("Content-Disposition: form-data; name=\"" + param.getKey() + "\"" + lineEnd);
- sb.append(lineEnd);
- sb.append(param.getValue() + lineEnd);
- }
- try {
- output.writeBytes(sb.toString());// 发送表单字段数据
- } catch (IOException e) {
- thrownew RuntimeException(e);
- }
- }
- /**
- * 直接通过 HTTP 协议提交数据到服务器,实现表单提交功能。
- * @param actionUrl 上传路径
- * @param params 请求参数key为参数名,value为参数值
- * @param files 上传文件信息
- * @return 返回请求结果
- */
- public String post(String actionUrl, Set<Map.Entry<Object,Object>> params, Image[] files) {
- HttpURLConnection conn = null;
- DataOutputStream output = null;
- BufferedReader input = null;
- try {
- URL url = new URL(actionUrl);
- conn = (HttpURLConnection) url.openConnection();
- conn.setConnectTimeout(120000);
- conn.setDoInput(true); // 允许输入
- conn.setDoOutput(true); // 允许输出
- conn.setUseCaches(false); // 不使用Cache
- conn.setRequestMethod("POST");
- conn.setRequestProperty("Connection", "keep-alive");
- conn.setRequestProperty("Content-Type", multipart_form_data + "; boundary=" + boundary);
- conn.connect();
- output = new DataOutputStream(conn.getOutputStream());
- addImageContent(files, output); // 添加图片内容
- addFormField(params, output); // 添加表单字段内容
- output.writeBytes(twoHyphens + boundary + twoHyphens + lineEnd);// 数据结束标志
- output.flush();
- int code = conn.getResponseCode();
- if(code != 200) {
- thrownew RuntimeException("请求‘" + actionUrl +"’失败!");
- }
- input = new BufferedReader(new InputStreamReader(conn.getInputStream()));
- StringBuilder response = new StringBuilder();
- String oneLine;
- while((oneLine = input.readLine()) != null) {
- response.append(oneLine + lineEnd);
- }
- return response.toString();
- } catch (IOException e) {
- thrownew RuntimeException(e);
- } finally {
- // 统一释放资源
- try {
- if(output != null) {
- output.close();
- }
- if(input != null) {
- input.close();
- }
- } catch (IOException e) {
- thrownew RuntimeException(e);
- }
- if(conn != null) {
- conn.disconnect();
- }
- }
- }
- publicstaticvoid main(String[] args) {
- try {
- String response = "";
- BufferedReader in = new BufferedReader(new FileReader("config/actionUrl.properties"));
- String actionUrl = in.readLine();
- // 读取表单对应的字段名称及其值
- Properties formDataParams = new Properties();
- formDataParams.load(new FileInputStream(new File("config/formDataParams.properties")));
- Set<Map.Entry<Object,Object>> params = formDataParams.entrySet();
- // 读取图片所对应的表单字段名称及图片路径
- Properties imageParams = new Properties();
- imageParams.load(new FileInputStream(new File("config/imageParams.properties")));
- Set<Map.Entry<Object,Object>> images = imageParams.entrySet();
- Image[] files = new Image[images.size()];
- int i = 0;
- for(Map.Entry<Object,Object> image : images) {
- Image file = new Image(image.getValue().toString(), image.getKey().toString());
- files[i++] = file;
- }
- // Image file = new Image("images/apple.jpg", "upload_file");
- // Image[] files = new Image[0];
- // files[0] = file;
- response = new UploadImage().post(actionUrl, params, files);
- System.out.println("返回结果:" + response);
- } catch (IOException e) {
- e.printStackTrace();
- }
- }
- }
转载于:https://www.cnblogs.com/loushangshaonian/archive/2013/04/19/3030394.html
摘抄 ander图片上传相关推荐
- html显示数据库图片django,django将图片上传数据库后在前端显式的方法
1.使用ImageField先安装pillow模块 pip install pillow 2.在app的models中设置 class Image(models.Model): pic_name=mo ...
- yii2框架原生的结合框架使用的图片上传
首先我们要从model层开始写起,主要是为了创建验证规则,还有图片上传的路径以及图片的命名规则(UploadForm.php) 接下来我们要在控制器层写好业务逻辑,就是什么情况下直接在调用model层 ...
- java flex 图片上传_flex上传图片到java服务器
今天弄flex上传图片到java,现在弄成功,中间也经常一点小波折,现记录一下.重点在java侧的实现. flex侧:文件上载到在url参数中传递的URL.该URL必须是配置为接受上载的服务器脚本.F ...
- js表单提交,支持图片上传,包含后端php代码
微信小程序开发交流qq群 581478349 承接微信小程序开发.扫码加微信. <html><head><meta http-equiv="Conte ...
- ckeditor finder php,CKEDITOR CKFINDER的图片上传配置(C#/asp.net/php)
CKEDITOR+CKFINDER的图片上传配置(C#/asp教程.net/php教程) php keditor的代码全部重写,但里面没有了上传功能,只是一个纯粹的文件在线编辑器,如果需要上传图片,还 ...
- 图片上传(加水印、缩略图、远程保存)的简单例子
图片上传(加水印.缩略图.远程保存)的简单例子(应用于51aspx.com) 该源码下载地址:http://51aspx.com/CV/ImageUpload 今天看到xiongeee发的文章使用使用 ...
- 使用summernote实现复制图片即可实现图片上传
个人资源与分享网站:http://xiaocaoshare.com/ 1.页面结构 <script src="../statics/js/plugins/summernote/summ ...
- js实现图片上传本地预览
演示地址:https://xibushijie.github.io/static/uploadImg.html <!DOCTYPE> <html><head>< ...
- SpringBoot 2.0 多图片上传加回显
点击上方蓝色"方志朋",选择"设为星标" 回复"666"获取独家整理的学习资料! 本文来源:http://r6f.cn/crEY 这两天公司 ...
- alert()的功能_前端实现简单的图片上传小图预览功能
<!DOCTYPE html> <html lang="en"> <head><meta charset="UTF-8" ...
最新文章
- 2017,公司必须换掉的六种人,别心软!
- UI设计师必须了解:2015年十大移动端APP设计主流趋势
- 播放视频和音频文件java
- 该!这个电视频道违规播出非法集资广告 被停播30天
- win11找不到开启蓝牙开关,设备管理器也没有蓝牙
- 安装Linux无盘工作站
- html阻止超链接跳转,009_阻止html标签默认事件的执行,比如阻止超链接默认点击事件的执行...
- PowerDesigner 16.5下载安装包
- git gitlan 切糕入门
- PAT(甲级)1148 Werewolf - Simple Version(枚举)
- IoT僵尸网络Miori通过ThinkPHP远程代码执行漏洞进行传播
- android 小米8底部有一大片黑色
- 分布式数据库如何实现主键全局自增?
- PTA 6 循环日程表
- 易盾php,PHP接入网易易盾验证码
- js 操作字符串,
- Android视频编码--H264编码
- Linux创建share共享文件夹
- 机器视觉丨平行面光源的原理丨打光案例及尺寸图
- Android开发必备(干货源码放送大)