图片等文件的上传

先有一个示例:

import java.io.*;
import java.net.HttpURLConnection;
import java.net.MalformedURLException;
import java.net.URL;
import java.util.Iterator;
import java.util.Map;
import java.util.UUID;

import android.util.Log;

public class UploadUtil {
    private static final String TAG = "uploadFile";
    private static final int TIME_OUT = 60 * 1000;
    private static final String CHARSET = "utf-8";

    public static String uploadFile(File file, String fileKey,
                                    String RequestURL, final Map<String, String> param) {
        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);//从主机读取数据的超时时间(单位:ms)
              conn.setConnectTimeout(TIME_OUT);//连接主机的超时时间(单位:ms)
              conn.setDoInput(true);//设置是否从HttpURLConnection读入,默认情况下是true
            conn.setDoOutput(true);//设置是否向HttpURLConnection输出,因为这个是post请求,参数要放在http正文内,因此需要
            //设为true,默认情况下是false
            conn.setUseCaches(false);//Post请求不能使用缓存
              conn.setRequestMethod("POST");//设置请求的方式是Post,默认是Get
            conn.setRequestProperty("Charset", CHARSET);//setRequestProperty设置HttpURLConnection请求头里面的属性,比如格式
            //UA等,不设置自然有默认的,具体设置什么也要看服务器端的约定
              conn.setRequestProperty("connection", "keep-alive");
            conn.setRequestProperty("Content-Type", CONTENT_TYPE + ";boundary="
                    + BOUNDARY);

            if (file != null) {
//                OutputStream outputStream=conn.getOutputStream();
                DataOutputStream dos = new DataOutputStream(
                        conn.getOutputStream());//通过输出流对象构建对象输出流对象,以实现输出可序列化的对象
                   StringBuffer sb = new StringBuffer();
                sb.append(PREFIX);
                sb.append(BOUNDARY);
                sb.append(LINE_END);

                String params = "";

                if (param != null && param.size() > 0) {
                    Iterator<String> it = param.keySet().iterator();
                    while (it.hasNext()) {
                        sb = null;
                        sb = new StringBuffer();
                        String key = it.next();
                        String value = param.get(key);
                        sb.append(PREFIX).append(BOUNDARY).append(LINE_END);
                        sb.append("Content-Disposition: form-data; name=\"")
                                .append(key).append("\"").append(LINE_END)
                                .append(LINE_END);
                        sb.append(value).append(LINE_END);
                        params = sb.toString();
                        dos.write(params.getBytes());
                    }
                }
                sb = null;
                params = null;
                sb = new StringBuffer();

                sb.append(PREFIX).append(BOUNDARY).append(LINE_END);
                sb.append("Content-Disposition: form-data; name=\"" + fileKey
                        + "\"; filename=\"" + file.getName() + "\"" + LINE_END);
                sb.append("Content-Type: application/octet-stream charset="
                        + CHARSET + LINE_END);
                sb.append(LINE_END);
                params = sb.toString();
                sb = null;

                // dos.write(sb.toString().getBytes());
                dos.write(params.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();//刷新对象输出流,将任何字节都写入潜在的流中,此处为DataOutputStream

                int res = conn.getResponseCode();
                Log.e(TAG, "response code:" + res);
                // if(res==200)
                // {
                Log.e(TAG, "request success");
                InputStream input = conn.getInputStream();//将内存缓存区中封装好的完整的HTTP请求电文发送到服务点
                //实际发送请求的代码就在这句
                   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;
    }
}

调用方法:

Map<String, String> params = new HashMap<String, String>();
params.put("ticket", mTicket);

String result = UploadUtil.uploadFile(file, "fileData",
AppConfig.UPLOAD_SERVERURL, params);
message.obj = result;

下面是HttpURLConnection的有关基础::

/*

* URL请求的类别分为二类,GET与POST请求。二者的区别在于:
* a:) get请求可以获取静态页面,也可以把参数放在URL字串后面,传递给servlet,
* b:) post与get的不同之处在于post的参数不是放在URL字串里面,而是放在http请求的正文内。
*/
URL url = new URL("http://localhost:8080/TestHttpURLConnectionPro.do");

HttpURLConnection urlConn = (HttpURLConnection) url.openConnection();

// 设置是否向httpUrlConnection输出,因为这个是post请求,参数要放在
// http正文内,因此需要设为true, 默认情况下是false;
urlConn.setDoOutput(true);

// 设置是否从httpUrlConnection读入,默认情况下是true;
urlConn.setDoInput(true);

// Post 请求不能使用缓存
urlConn.setUseCaches(false);

// 设定传送的内容类型是可序列化的java对象
// (如果不设此项,在传送序列化对象时,当WEB服务默认的不是这种类型时可能抛java.io.EOFException)
//setRequestProperty设置HttpURLConnection请求头里面的属性,比如格式 ,
  //UA等,不设置自然有默认的,具体设置什么也要看服务器端的约定
urlConn.setRequestProperty("Content-type","application/x-java-serialized-object");
// 设定请求的方法为"POST",默认是GET
urlConn.setRequestMethod("POST");
// 连接,上面对urlConn的所有配置必须要在connect之前完成,
urlConn.connect();
// 此处getOutputStream会隐含的进行connect (即:如同调用上面的connect()方法,
// 所以在开发中不调用上述的connect()也可以)。
OutputStream outStrm = urlConn.getOutputStream();
// 现在通过输出流对象构建对象输出流对象,以实现输出可序列化的对象。
ObjectOutputStream oos = new ObjectOutputStream(outStrm);
// 向对象输出流写出数据,这些数据将存到内存缓冲区中
oos.writeObject(new String("我是测试数据"));
// 刷新对象输出流,将任何字节都写入潜在的流中(些处为ObjectOutputStream)
oos.flush();
// 关闭流对象。此时,不能再向对象输出流写入任何数据,先前写入的数据存在于内存缓冲区中,
// 再调用下边的getInputStream()函数时才把准备好的http请求正式发送到服务器
oos.close();
// 调用HttpURLConnection连接对象的getInputStream()函数,
// 将内存缓冲区中封装好的完整的HTTP请求电文发送到服务端。
InputStream inStrm = urlConn.getInputStream(); // <===注意,实际发送请求的代码段就在这里
//----------------------------------
/*
* Post传参的方法
*/
OutputStream os = urlConn.getOutputStream();
String param = new String();
param = "CorpID=123&LoginName=qqq&name=" + URLEncoder.encode("汉字","GBK"); ;
os.write(param.getBytes());
//----------------------------------
/*
* 超时设置,防止 网络异常的情况下,可能会导致程序僵死而不继续往下执行
*/
//JDK 1.5以前的版本,只能通过设置这两个系统属性来控制网络超时:
//连接主机的超时时间(单位:毫秒)
System.setProperty("sun.net.client.defaultConnectTimeout", "30000");
//从主机读取数据的超时时间(单位:毫秒)
System.setProperty("sun.net.client.defaultReadTimeout", "30000");
//在JDK 1.5以后可以这样来设置超时时间
HttpURLConnection urlCon = (HttpURLConnection)url.openConnection();
urlCon.setConnectTimeout(30000);
urlCon.setReadTimeout(30000);
//----------------------------------
/*
* 总结:
* HttpURLConnection的connect()函数,实际上只是建立了一个与服务器的tcp连接,并没有实际发送http请求。
* 无论是post还是get,http请求实际上直到HttpURLConnection的getInputStream()这个函数里面才正式发送出去。

* 对HttpURLConnection对象的一切配置都必须要在connect()函数执行之前完成。
* 而对outputStream的写操作,又必须要在inputStream的读操作之前。
* 这些顺序实际上是由http请求的格式决定的。
*
* 在http头后面紧跟着的是http请求的正文,正文的内容是通过outputStream流写入的,
* 实际上outputStream不是一个网络流,充其量是个字符串流,往里面写入的东西不会立即发送到网络,
* 而是存在于内存缓冲区中,待outputStream流关闭时,根据输入的内容生成http正文。
* 至此,http请求的东西已经全部准备就绪。在getInputStream()函数调用的时候,就会把准备好的http请求
* 正式发送到服务器了,然后返回一个输入流,用于读取服务器对于此次http请求的返回信息。由于http
* 请求在getInputStream的时候已经发送出去了(包括http头和正文),因此在getInputStream()函数
* 之后对connection对象进行设置(对http头的信息进行修改)或者写入outputStream(对正文进行修改)
* 都是没有意义的了,执行这些操作会导致异常的发生。
*
*/
时间: 2024-07-30 18:03:11

图片等文件的上传的相关文章

h5实现本地图片或文件的上传

首先放一个今天学到的小demo: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>测试</title> <style> * { margin: 0; padding: 0; } .myImg { width: 200px; } #imgs { width: 500px; height: 500

HTML5实现图片文件异步上传

利用HTML5的新特点做文件异步上传非常简单方便,本文主要展示JS部分,html结构.下面的代码并未使用第三发库,如果有参照,请注意一些未展现出来的代码片段.我这边的效果预览: 1.文件未选择 2.文件已选择 HTML代码部分: 思路:下面代码中我利用css的z-index属性将input="file"标签隐藏在了id=btnSelect元素下面,通过触发a标签的点击后,弹出文件选择框.下面的masklayer用于点击确认按钮后的弹出层,避免用户重复点击确认按钮. <div id

ssh整合问题总结--在添加商品模块实现图片(文件)的上传

今天在做毕设(基于SSH的网上商城项目)中碰到了一个文件上传的需求,就是在后台管理员的商品模块中,有一个添加商品,需要将磁盘上的图片上传到tomcat保存图片的指定目录中: 完成这个功能需要两个步,第一是图片上传,第二是保存到数据库,在完成这个功能时候碰到了一些小问题,所以把完整的步骤记录一下: 第一步,在form标签下,添加一个属性,enctype="multipart/form-data",  我刚开始脑袋短路将这个属性写到了type为file的那么input标签下,结果死活提交不

【转】文件各种上传,离不开的表单

阅读目录 利用表单实现文件上传 表单异步上传(jquery.form插件) 模拟表单数据上传(FormData) 分片上传 使用HTML5 拖拽.粘贴上传 上传插件(WebUploader) 总结 作为程序员的我们,经常会要用到文件的上传和下载功能.到了需要用的时候,各种查资料.有木有..有木有....为了方便下次使用,这里来做个总结和备忘. 利用表单实现文件上传 最原始.最简单.最粗暴的文件上传. 前端代码: //方式1 <form action="/Home/SaveFile1&quo

jQuery+php实现ajax文件即时上传

很多项目中需要用到即时上传功能,比如,选择本地图片后,立即上传并显示图像.本文结合实例讲解如何使用jQuery和PHP实现Ajax即时上传文件的功能,用户只需选择本地图片确定后即实现上传,并显示上传进度条,上传完成后,显示图片信息. 查看演示DEMO下载源码 HTML 本示例基于jQuery以及相当出色的jquery.form插件,所以,先要载入jquery库和form插件.  <script type="text/javascript" src="jquery.min

复制文件(上传至共享文件夹)

复制文件(上传至共享文件夹) 功  能:复制文件.也可以指定是否覆盖同名的目标文件. 语  法:FileCopy ( sourcefile , targetfile {, replace}) 参  数: sourcefile:string 类型,指定要复制文件的名称(源文件名称): targetfile:string 类型,指定要复制到哪一个文件(目标文件名称): replace:Boolean类型,指定当目标文件已经存在时,是否覆盖同名文件. True --- 覆盖同名文件: False --

jquery文件批量上传控件Uploadify3.2(java springMVC)

人比較懒  有用为主 不怎么排版了 先放上Uploadify的官网链接:http://www.uploadify.com/  -->里面能够看到PHP的演示样例,属性说明,以及控件下载地址.分flash版(免费)和html5版(收费). 官网上能够看到效果演示. 另外在网上找到了一份Uploadify3.2的中文API文档.能够在我上传的资源里面下载. 以下就是一个基于springMVC的文件上传演示样例,看起来可能比文档更直观一些··· 1.下载插件放到项目中 2.在jsp页面中引入下面JS和

SpringMVC实现文件的上传和下载

前些天一位江苏经贸的学弟跟我留言问了我这样一个问题:"用什么技术来实现一般网页上文件的上传和下载?是框架还是Java中的IO流".我回复他说:"使用SpringMVC框架可以做到这一点,因为SpringMVC为文件的上传提供了直接的支持,但需要依赖Apache提供Commons FileUpload组件jar包."鉴于这个问题,我上网也百度了一下,网上很多都是介绍的使用IO流来实现文件的上传和下载,也有说到框架的,但介绍的并不是很完整,今天小钱将和大家介绍使用Spr

文件拖动上传jsp

在大型企业的开发过程中,很多比较有趣而实际的功能往往都是让大家望而却步,我给大家带来一个百度云盘和360云盘的HTML5多文件拖动上传技术: 1:记得导入:common-fileupload.jar包. 上传upload.jsp页面 <%@page import="org.apache.struts2.json.JSONUtil"%> <%@page import="java.io.File"%> <%@page import=&quo