• 下载文件


        @RequestMapping("/downFile")
        public void downFile(HttpServletRequest request, HttpServletResponse response) throws MalformedURLException {
            String s = "http://www.gov.cn/premier/2020-12/14/5569425/images/461c0ea163c94683ac0b0cb7bf4eaf39.jpg";
            URL url = new URL(s);
            File file = new File(s);
            String fileName = file.getName();
            String ext = fileName.substring(fileName.lastIndexOf(".") + 1);
            String agent = (String) request.getHeader("USER-AGENT"); // 判断浏览器类型
            try {
                if (agent != null && agent.indexOf("Fireforx") != -1) {
                    fileName = new String(fileName.getBytes("UTF-8"), "iso-8859-1"); // UTF-8编码,防止输出文件名乱码
                } else {
                    fileName = URLEncoder.encode(fileName, "UTF-8");
                }
            } catch (UnsupportedEncodingException e) {
                e.printStackTrace();
            }
    
            BufferedInputStream bis = null;
            OutputStream os = null;
            response.reset();
            response.setCharacterEncoding("utf-8");
            if (ext == "docx") {
                response.setContentType("application/msword"); // word格式
            } else if (ext == "pdf") {
                response.setContentType("application/pdf"); // word格式
            }
            response.setHeader("Content-Disposition", "attachment; filename=" + fileName);
    
            try {
                bis = new BufferedInputStream(url.openStream());
                byte[] b = new byte[bis.available() + 1000];
                int i = 0;
                os = response.getOutputStream(); // 直接下载导出
                while ((i = bis.read(b)) != -1) {
                    os.write(b, 0, i);
                }
                os.flush();
                os.close();
            } catch (IOException e) {
                e.printStackTrace();
            } finally {
                if (os != null) {
                    try {
                        os.close();
                    } catch (IOException e) {
                        e.printStackTrace();
                    }
                }
                if (bis != null) {
                    try {
                        bis.close();
                    } catch (IOException e) {
                        e.printStackTrace();
                    }
                }
            }
        }
  • 相关阅读:
    cnetos7安装mysql并开启慢日志查询
    ansible-playbook安装zabbix_server,agent监控
    mysql性能优化之服务器参数配置-内存配置
    什么影响了mysql的性能-存储引擎层
    什么影响了mysql的性能-硬件资源及系统方面优化
    redis基本操作使用
    cmd下操作MySQL
    Win10安装MySQL
    Linux 操作
    PySpark—DataFrame笔记
  • 原文地址:https://www.cnblogs.com/tjlr/p/14141201.html
Copyright © 2020-2023  润新知