zoukankan      html  css  js  c++  java
  • 文件下载断点续传插件webupload插件

    需求:

    支持文件批量下载。

    使用JS能够实现批量下载,能够提供接口从指定url中下载文件并保存在本地指定路径中。

    服务器不需要打包。

    支持大文件断点下载。比如下载10G的文件。

    PC端全平台支持。Windows,macOS,Linux

    全浏览器支持。ie6,ie7,ie8,ie9,ie10,ie11,edge,firefox,chrome,safari

    支持文件夹结构下载。不希望在服务器打包,而是直接下载文件夹,下载后在本地文件夹结构和服务器保持一致。

    支持从URL中下载文件。

    支持JSON数据结构。

    import java.io.BufferedInputStream;

    import java.io.File;

    import java.io.FileOutputStream;

    import java.io.IOException;

    import java.io.OutputStream;

    import java.net.HttpURLConnection;

    import java.net.MalformedURLException;

    import java.net.URL;

    import java.net.URLConnection;

    public class FileDown {

        /**

         * 说明:根据指定URL将文件下载到指定目标位置

         *

         * @param urlPath 下载路径

         * @param downloadDir 文件存放目录

         * @return 返回下载文件

         */

        @SuppressWarnings("finally")

        public static File downloadFile(String urlPath, String downloadDir) {

            File file = null;

            try {

                // 统一资源

                URL url = new URL(urlPath);

                // 连接类的父类,抽象类

                URLConnection urlConnection = url.openConnection();

                // http的连接类

                HttpURLConnection httpURLConnection = (HttpURLConnection) urlConnection;

                //设置超时

                httpURLConnection.setConnectTimeout(1000*5);

                //设置请求方式,默认是GET

                httpURLConnection.setRequestMethod("GET");

                // 设置字符编码

                httpURLConnection.setRequestProperty("Charset", "UTF-8");

                // 打开到此 URL引用的资源的通信链接(如果尚未建立这样的连接)。

                httpURLConnection.connect();

                // 建立链接从请求中获取数据

                BufferedInputStream bin = new BufferedInputStream(httpURLConnection.getInputStream());

                // 指定文件名称(有需求可以自定义)

                String fileFullName = "aaa.zip";

                // 指定存放位置(有需求可以自定义)

                String path = downloadDir + File.separatorChar + fileFullName;

                file = new File(path);

                // 校验文件夹目录是否存在,不存在就创建一个目录

                if (!file.getParentFile().exists()) {

                    file.getParentFile().mkdirs();

                }

                OutputStream out = new FileOutputStream(file);

                int size = 0;

                long len = 0;

                byte[] buf = new byte[2048];

                while ((size = bin.read(buf)) != -1) {

                    len += size;

                    out.write(buf, 0, size);

                }

                // 关闭资源

                bin.close();

                out.close();

                System.out.println("文件下载成功,文件大小:"+len/1024+"kb");

            } catch (MalformedURLException e) {

                e.printStackTrace();

            } catch (IOException e) {

                e.printStackTrace();

                System.out.println("文件下载失败!");

            } finally {

                return file;

            }

        }

        /**

         * 测试

         *

         * @param args

         */

        public static void main(String[] args) {

            // 指定资源地址,下载文件测试

            downloadFile("http://baidu.com", "d:/bill/2018-11-07/");

        }

    }

    js批量下载文件的代码

    $("#btn-down-files").click(function () {

        if (downer.Config["Folder"] == "") { downer.open_folder(); return; }

        var urls = [

            { fileUrl: "http://res2.ncmem.com/res/images/ie11.png" }

            , { fileUrl: "http://res2.ncmem.com/res/images/up6.1/down.png" }

            , { fileUrl: "http://res2.ncmem.com/res/images/firefox.png" }

            , { fileUrl: "http://res2.ncmem.com/res/images/edge.png" }

            , { fileUrl: "http://res2.ncmem.com/res/images/up6.1/cloud.png" }

            , { fileUrl: "http://res2.ncmem.com/res/images/home/w.png" }

            , { fileUrl: "http://res2.ncmem.com/res/images/img.png" }

        ];

        downer.app.addUrls(urls);

    });

    批量下载json格式的数据

    $("#btn-down-json").click(function () {

        if (downer.Config["Folder"] == "") { downer.open_folder(); return; }

        var fd = {

            nameLoc: "图片列表"

            , files: [

                { fileUrl: "http://res2.ncmem.com/res/images/ie11.png" }

                , { fileUrl: "http://res2.ncmem.com/res/images/up6.1/down.png" }

                , { fileUrl: "http://res2.ncmem.com/res/images/firefox.png" }

                , { fileUrl: "http://res2.ncmem.com/res/images/edge.png" }

                , { fileUrl: "http://res2.ncmem.com/res/images/up6.1/cloud.png" }

                , { fileUrl: "http://res2.ncmem.com/res/images/home/w.png" }

                , { fileUrl: "http://res2.ncmem.com/res/images/img.png" }

            ]

        };

        downer.app.addJson(fd);

    });

    效果:

    网上例子:http://blog.ncmem.com/wordpress/2019/08/28/java批量下载/

  • 相关阅读:
    redis.conf配置详细解析
    laravel框架的注入
    10 个免费高清图片素材下载网站。#免版权# #设计# #图片处理#
    本地Git连接GitLab(服务器)远程仓库
    基于Docker的Mysql主从复制
    解决git本地代码推服务器每次都要输入用户名和密码的问题
    Laravel上传文件(单文件,多文件)
    php的精度计算问题(bcadd和bcsub)
    POJ 1573 Robot Motion(简单模拟)
    POJ 2996 Help Me with the Game(模拟)
  • 原文地址:https://www.cnblogs.com/songsu/p/13404707.html
Copyright © 2011-2022 走看看