zoukankan      html  css  js  c++  java
  • Java实现从服务器下载文件到本地的工具类

    话不多说,直接上代码......

    import javax.servlet.http.HttpServletRequest;
    import javax.servlet.http.HttpServletResponse;
    import java.io.*;
    import java.net.URLEncoder;
    
    /***
     * 将文件内容响应到浏览器
     */
    public class DownloadUtil {
    
        // 字符编码格式
        private static String charsetCode = "utf-8";
    
    
        /**
         * 文件的内容类型
         */
        private static String getFileContentType(String name){
            String result = "";
            String fileType = name.toLowerCase();
            if (fileType.endsWith(".png")) {
                result = "image/png";
            } else if (fileType.endsWith(".gif")) {
                result = "image/gif";
            } else if (fileType.endsWith(".jpg") || fileType.endsWith(".jpeg")) {
                result = "image/jpeg";
            } else if(fileType.endsWith(".svg")){
                result = "image/svg+xml";
            }else if (fileType.endsWith(".doc")) {
                result = "application/msword";
            } else if (fileType.endsWith(".xls")) {
                result = "application/x-excel";
            } else if (fileType.endsWith(".zip")) {
                result = "application/zip";
            } else if (fileType.endsWith(".pdf")) {
                result = "application/pdf";
            } else {
                result = "application/octet-stream";
            }
            return result;
        }
    
        /**
         * 下载文件
         * @param path 文件的位置
         * @param fileName 自定义下载文件的名称
         * @param resp http响应
         * @param req http请求
         */
        public static void downloadFile(String path, String fileName, HttpServletResponse resp, HttpServletRequest req){
    
            try {
                File file = new File(path);
                /**
                 * 中文乱码解决
                 */
                String type = req.getHeader("User-Agent").toLowerCase();
                if(type.indexOf("firefox")>0 || type.indexOf("chrome")>0){
                    /**
                     * 谷歌或火狐
                     */
                    fileName = new String(fileName.getBytes(charsetCode), "iso8859-1");
                }else{
                    /**
                     * IE
                     */
                    fileName = URLEncoder.encode(fileName, charsetCode);
                }
                // 设置响应的头部信息
                resp.setHeader("content-disposition", "attachment;filename=" + fileName);
                // 设置响应内容的类型
                resp.setContentType(getFileContentType(fileName)+"; charset=" + charsetCode);
                // 设置响应内容的长度
                resp.setContentLength((int) file.length());
                // 输出
                outStream(new FileInputStream(file), resp.getOutputStream());
            } catch (Exception e) {
                System.out.println("执行downloadFile发生了异常:" + e.getMessage());
            }
        }
    
        /**
         * 基础字节数组输出
         */
        private static void outStream(InputStream is, OutputStream os) {
            try {
                byte[] buffer = new byte[10240];
                int length = -1;
                while ((length = is.read(buffer)) != -1) {
                    os.write(buffer, 0, length);
                    os.flush();
                }
            } catch (Exception e) {
                System.out.println("执行 outStream 发生了异常:" + e.getMessage());
            } finally {
                try {
                    os.close();
                } catch (IOException e) {
                }
                try {
                    is.close();
                } catch (IOException e) {
                }
            }
        }
    
    }

    使用。。(  springboot项目  ) 

  • 相关阅读:
    jperf windows
    Eclipse+Maven命令创建webapp项目<三>
    Eclipse+Maven创建webapp项目<二>
    Eclipse+Maven创建webapp项目<一>
    在java中定义有几种类加载器
    JAVA创建对象有哪几种方式 ?
    js创建对象的几种常用方式小结(推荐)
    maven安装以及eclipse配置maven
    MyEclipse 10.0安装及激活步骤
    jdk下载网址
  • 原文地址:https://www.cnblogs.com/oukele/p/10982075.html
Copyright © 2011-2022 走看看