zoukankan      html  css  js  c++  java
  • 文件通过流的方式下载时的文件名设置

    response.addHeader("Content-Disposition", "attachment;filename="); 

    这里的文件名最好用URLDecode.decode(fileName, "UTF-8")处理过,不然中文会有乱码

    Servlet例子:

    package com.cj.test1_10;
    
    import java.io.FileInputStream;
    import java.io.IOException;
    import java.io.InputStream;
    import java.net.URLEncoder;
    
    import javax.servlet.ServletException;
    import javax.servlet.ServletOutputStream;
    import javax.servlet.annotation.WebServlet;
    import javax.servlet.http.HttpServlet;
    import javax.servlet.http.HttpServletRequest;
    import javax.servlet.http.HttpServletResponse;
    
    /**
     * Servlet implementation class Test9
     */
    @WebServlet("/Test9")
    public class Test9 extends HttpServlet {
        private static final long serialVersionUID = 1L;
           
        public Test9() {
            super();
        }
    
        protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
            doPost(request, response);
        }
    
        protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
            //获取文件的绝对路径
            String realPath = this.getServletContext().getRealPath("/就来中文.jpg");
            System.out.println("realPath:"+realPath);
            //获取要下载的文件名
            String fileName = realPath.substring(realPath.lastIndexOf("\")+1);
            System.out.println("fileName:"+fileName);
            //设置响应头,以下载的形式打开文件
            response.setHeader("content-disposition", "attachment;fileName="+URLEncoder.encode(fileName, "UTF-8"));
            //获取要下载的文件输入流
            InputStream in = new FileInputStream(realPath);
            int len = 0;
            //创建数据缓冲区
            byte [] buffer = new byte[1024];
            //创建输出流
            ServletOutputStream out = response.getOutputStream();
            while((len = in.read(buffer))>0){
                out.write(buffer, 0, len);
            }
        }
    
    }
  • 相关阅读:
    东南亚“美团” Grab 的搜索索引优化之法
    linux中init.d文件夹的说明
    缓存踩踏:Facebook 史上最严重的宕机事件分析
    burp suite
    千万实例可观测采集器iLogtail
    grep 匹配多个关键字
    127.0.0.1和0.0.0.0
    Python 爬虫进阶必备 | 某常见 cookie 加密算法逻辑分析 (加速乐 jsl) https://mp.weixin.qq.com/s/fKuPs2b3MvOi8y4hPVbgNA
    百度商业大规模高性能全息日志检索技术揭秘
    ECB加密 CBC
  • 原文地址:https://www.cnblogs.com/cuijiade/p/9209463.html
Copyright © 2011-2022 走看看