HTTP大文件分片(分流)上传

ango907 2017-10-24 10:58:20
JAVA服务器端500MB文件如何分流为每200MB进行HTTP数据传输?
...全文
1115 2 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
风之诗- 2017-10-24
  • 打赏
  • 举报
回复
在本地你就可以通过IO流进行文件分块,传输过去后那边通知文件编号再使用IO流合并为一个文件就行了
ango907 2017-10-24
  • 打赏
  • 举报
回复
如下代码如何进行分流改造:

private String UploadVideo(Map<String, String> tmpMap,String tPathName) throws ClientProtocolException, IOException {
        // 返回tETag
        String tETag = "";
        // 连接
        HttpURLConnection conn = null;
        // 传递参数
        OutputStreamWriter tStreamWriter = null;
        // 接受参数
        InputStream tInputStream = null;

        String nextLine = "\r\n";
        String dividerStart = "--";
        String BOUNDARY = "******8888668ec";

        try{
            URL url = new URL(tmpMap.get("url"));
            conn = (HttpURLConnection) url.openConnection();
            conn.setRequestMethod("PUT");// 提交模式
            conn.setConnectTimeout(DI_CommonType.ConnectTimeout);// 连接超时 单位毫秒
            conn.setDoOutput(true);// 是否输入参数
            conn.setDoInput(true); // 是否接收参数
            conn.setUseCaches(false);// 是否缓存
            conn.setRequestProperty("Connection", "Keep-Alive");
            conn.setRequestProperty("Charset","UTF-8");
            conn.setRequestProperty("User-Agent", "Mozilla/5.0 (Windows; U; Windows NT 6.1; zh-CN; rv:1.9.2.6)");
            // 分界符
            conn.setRequestProperty("Content-Type", "multipart/form-data; boundary=" + BOUNDARY);
            // 定义写入数据流
            DataOutputStream tDataOutputStream = new DataOutputStream(conn.getOutputStream());
            tDataOutputStream.writeBytes(dividerStart + BOUNDARY + nextLine);
            //设置与上传文件相关的信息
            tDataOutputStream.writeBytes("Content-Disposition: form-data; name=\"file\"; filename=\""
                    + tFilePathc.substring(tFilePathc.lastIndexOf("/") + 1) + "\"" + nextLine);
            tDataOutputStream.writeBytes(nextLine);
            FileInputStream fis = new FileInputStream(tFilePathc);
            byte[] buffer = new byte[1024 * 32];
            int count;
            // 读取文件内容,并写入OutputStream对象
            while ((count = fis.read(buffer)) != -1) {
                tDataOutputStream.write(buffer, 0, count);
            }
            fis.close();
            tDataOutputStream.writeBytes(nextLine);
            tDataOutputStream.writeBytes(dividerStart + BOUNDARY + dividerStart + nextLine);
            tDataOutputStream.flush();

            // 接收参数
            int tResponseCode = conn.getResponseCode();
            Map<String,List<String>> headerFields = conn.getHeaderFields();
            System.out.println(headerFields.get("ETag"));

            if (200==tResponseCode) {
                tETag = headerFields.get("ETag").toString();
            }

        }catch(IOException e){
            try {
                System.out.println(conn.getResponseCode());
            } catch (IOException e1) {
                e1.printStackTrace();
            }
//            e.printStackTrace();
            System.out.println("通信异常!+++");
        }finally {
            try {
                if (null!=tStreamWriter) {
                    tStreamWriter.close();
                }
                if (null!=tInputStream) {
                    tInputStream.close();
                }
                if (null!=conn) {
                    conn.disconnect();
                }
            } catch (IOException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }

        }
        return tETag;
    }

51,397

社区成员

发帖
与我相关
我的任务
社区描述
Java相关技术讨论
javaspring bootspring cloud 技术论坛(原bbs)
社区管理员
  • Java相关社区
  • 小虚竹
  • 谙忆
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧