JavaWeb下载文件

分析步骤

  1. 获取下载文件的URL请求路径
  2. 下载的文件名是什么?
  3. 想办法设置让浏览器能够支持下载我们需要的类型
  4. 创建下载文件的输入流将需要下载的文件读取
  5. 创建缓冲区
  6. 获取输出流(OutputStream)对象
  7. 用FileOutStream流将读取的文件写入到缓冲区
  8. 使用OutoutSream将缓冲区中的数据通过response响应回去给浏览器
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
    
    
        //这里用web服务来获取文件信息
        //获取当前上下文对象
        ServletContext servletContext = this.getServletContext();
        //获取生成web应用时的文件对应的项目路径
        String realPath = servletContext.getRealPath("/WEB-INF/classes/学习大纲.png");

        //截取当前文件对应的名字
        String filename = realPath.substring(realPath.lastIndexOf("\\") + 1);
        //如果文件存在中文进行转译编码
        filename= URLEncoder.encode(filename,"utf-8");
        //设置头信息,让浏览器能够支持下载的东西
        resp.setHeader("Content-Disposition","attachment;filename="+filename);

        //创建文件输入流读取文件信息
        FileInputStream fis=new FileInputStream(realPath);
        //创建缓冲区
        byte[] bytes=new byte[1024];
        int lent=0;
        //获取输出流对象
        ServletOutputStream outputStream = resp.getOutputStream();
        while ((lent=fis.read(bytes))!=-1){
    
    
            //将读取出的信息通过response响应回去给浏览器
            outputStream.write(bytes,0,lent);
        }
//        关闭流操作
        fis.close();
        outputStream.close();
    }

猜你喜欢

转载自blog.csdn.net/weixin_45608165/article/details/111402495