HttpServletResponse

2018-08-10  本文已影响0人  虫儿飞ZLEI

layout: post
title: HttpServletResponse
subtitle: 用法
date: 2018-04-16
author: ZL
header-img: img/20180416.jpg
catalog: true
tags:
- Response
- web文件下载


HttpServletResponse

所有的doget和dopost方法都会有request和response参数。

response和request

流程
浏览器的请求进过tomcat内部处理,被封装成一个request参数,放到了doget和dopost里面。
而response需要用户在doget或者dopost的代码里面为response添加内容,然后tomcat内部将这些内容封装好返回给浏览器。

原理性内容不看也罢

image
因为response代表响应,所以我们可以通过该对象分别设置Http响应的响应行,响 应头和响应体

response的一些API

下载文件的例子

  1. 下载名称没有中文的文件

    protected void doGet(HttpServletRequest request, HttpServletResponse response)
                throws ServletException, IOException {
    
            //获得要下载的文件的名称
            String filename = request.getParameter("filename");//a.flv
    
            //要下载的这个文件的类型-----客户端通过文件的MIME类型去区分类型
            response.setContentType(this.getServletContext().getMimeType(filename));
            //告诉客户端该文件不是直接解析 而是以附件形式打开(下载)
            response.setHeader("Content-Disposition", "attachment;filename="+filename);
    
            //获取文件的绝对路径
            String path = this.getServletContext().getRealPath("download/"+filename);
            //获得该文件的输入流
            InputStream in = new FileInputStream(path);
            //获得输出流---通过response获得的输出流 用于向客户端写内容
            ServletOutputStream out = response.getOutputStream();
            //文件拷贝的模板代码
            int len = 0;
            byte[] buffer = new byte[1024];
            while((len=in.read(buffer))>0){
                out.write(buffer, 0, len);
            }
    
            in.close();
            //out.close();
    
        }
    
  2. 下载包含中文名称的文件

    protected void doGet(HttpServletRequest request, HttpServletResponse response)
        throws ServletException, IOException {
    
      //*******文件名称是中文的下载*******
    
    
      //获得要下载的文件的名称
      String filename = request.getParameter("filename");//????.jpg
      //解决获得中文参数的乱码
      filename = new String(filename.getBytes("ISO8859-1"),"UTF-8");//美女.jpg
    
      
      //获得请求头中的User-Agent
      String agent = request.getHeader("User-Agent");
      //根据不同浏览器进行不同的编码
      String filenameEncoder = "";
      if (agent.contains("MSIE")) {
        // IE浏览器
        filenameEncoder = URLEncoder.encode(filename, "utf-8");
        filenameEncoder = filenameEncoder.replace("+", " ");
      } else if (agent.contains("Firefox")) {
        // 火狐浏览器
        BASE64Encoder base64Encoder = new BASE64Encoder();
        filenameEncoder = "=?utf-8?B?"
            + base64Encoder.encode(filename.getBytes("utf-8")) + "?=";
      } else {
        // 其它浏览器
        filenameEncoder = URLEncoder.encode(filename, "utf-8");             
      }
    
    
    
      //要下载的这个文件的类型-----客户端通过文件的MIME类型去区分类型
      response.setContentType(this.getServletContext().getMimeType(filename));
      //告诉客户端该文件不是直接解析 而是以附件形式打开(下载)----filename="+filename 客户端默认对名字进行解码
      response.setHeader("Content-Disposition", "attachment;filename="+filenameEncoder);
    
      //获取文件的绝对路径
      String path = this.getServletContext().getRealPath("download/"+filename);
      //获得该文件的输入流
      InputStream in = new FileInputStream(path);
      //获得输出流---通过response获得的输出流 用于向客户端写内容
      ServletOutputStream out = response.getOutputStream();
      //文件拷贝的模板代码
      int len = 0;
      byte[] buffer = new byte[1024];
      while((len=in.read(buffer))>0){
        out.write(buffer, 0, len);
      }
    
      in.close();
      //out.close();
    
    }
    
上一篇 下一篇

猜你喜欢

热点阅读