web14 HttpServletResponse

  • response是在请求网址时候和request一起创建好的只不过是空的,在doget方法中写入返回的数据(写给的是response,之后toncat将响应行响应头一起和数据封装成返回给客户端的响应)
  • 302是为了代码重定向使用的?重定向请求一次以上服务器
5秒之后跳转到百度:不常用因为是服务器端写死页面不会有动态效果
response.setHeader("refresh", "5,url=http://www.baidu.com");
  • html等辅助输入提示
    继续打开web→html Files→Editor→Content Assist
    修改Prompt when these characters are inserted:<=.abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVW
    js 类似值 :.abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVW

  • 写图片先有字节输入流需要去读图片(绝对地址用相对地址去获得),写时候用快速方法byte【1024】,while((len=in.read(byte))>0){out.write(byte,0,len)}

1.响应的response的运行流程

  • 因为response代表响应,所以我们可以通过该对象分别设置Http响应的响应行,响 应头和响应体
web14 HttpServletResponse_第1张图片
Paste_Image.png
  • 通过response设置响应行
    设置响应行的状态码
    setStatus(int sc)
  • 通过response设置响应头(add增加,set覆盖)
addHeader(String name, String value) 
addIntHeader(String name, int value) 
addDateHeader(String name, long date) 
setHeader(String name, String value) ***
setDateHeader(String name, long date) 
setIntHeader(String name, int value)
  • 通过response设置响应体
(1)响应体设置文本
PrintWriter getWriter()
获得字符流,通过字符流的write(String s)方法可以将字符串设置到response  缓冲区中,随后Tomcat会将response缓冲区中的内容组装成Http响应返回给浏览    器端。

关于设置中文的乱码问题
原因:response缓冲区的默认编码是iso8859-1,此码表中没有中文,可以通过 response的setCharacterEncoding(String charset) 设置response的编码

但我们发现客户端还是不能正常显示文字
原因:我们将response缓冲区的编码设置成UTF-8,但浏览器的默认编码是本地系  统的编码,因为我们都是中文系统,所以客户端浏览器的默认编码是GBK,我们可以  手动修改浏览器的编码是UTF-8。

我们还可以在代码中指定浏览器解析页面的编码方式,
通过response的setContentType(String type)方法指定页面解析时的编码是UTF-8
response.setContentType("text/html;charset=UTF-8");

上面的代码不仅可以指定浏览器解析页面时的编码,同时也内含        setCharacterEncoding的功能,所以在实际开发中只要编写    response.setContentType("text/html;charset=UTF-8");就可以解决页面输出中文乱码问题。

(2)响应头设置字节
ServletOutputStream  getOutputStream()
获得字节流,通过该字节流的write(byte[] bytes)可以向response缓冲区中写入字  节,在由Tomcat服务器将字节内容组成Http响应返回给浏览器。

2.文件下载

-----------重定向路径----
设置两个头
//  设置状态码302
//      response.setStatus(302);
//      重定向路径
//      response.setHeader("Location",   "/web14/servlet2");
//      效果一样
//  response.sendRedirect( "/web14/servlet2");
//5秒后跳转
    response.setHeader("refresh", "5,url=http://www.baidu.com");
-------乱码问题产生-------
有两方面:tomcat读取时候和读取完客户端展示时候
//      告诉tomcat存时候要utf-8
response.setCharacterEncoding("UTF-8");
//      告诉浏览器取时候要utf-8,仅这一句就可以让tomcat存时候也用u8
//response.setHeader("content-Type", "text/html;charset=utf-8");
//等同于
//response.setContentType( "text/html;charset=utf-8");
    PrintWriter writer = response.getWriter();
    writer.write("你好");
    
----------相当于上传图片浏览器展示---------------
public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        // 使用response获得字节输出流
        ServletOutputStream out = response.getOutputStream();
        // 获得文件字节流
        String path = getServletContext().getRealPath("a.jpg");
        FileInputStream in = new FileInputStream(path);
        int len = 0;
        byte[] butter = new byte[1024];
        while ((len = in.read(butter)) > 0) {
            out.write(butter, 0, len);
        }
        in.close();
        out.close();
    }
-------------下载文件---------

----展示的下载页面-------
a.flv
参数filename让response获取到文件名字 fileDownload是xml中url ----xml------ FileDownload /fileDownload --------servlet------- public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { 主要修改两个头ContentType和Content-Disposition // 从html的参数或取名字 String name = request.getParameter("filename"); // 告诉浏览器下载文件的类型参数是从全局web.xml中的mime类型转化 // response.setContentType(this.getServletContext().getMimeType(name)); // 告诉浏览器要附件下载而不是解开 response.setHeader("Content-Disposition", "attachment;filename=" + name); FileInputStream in = new FileInputStream(this.getServletContext().getRealPath("download/" + name)); 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();// out是response获取会自动被关闭 }
  • 1)告知浏览器文件的类型:response.setContentType(文件的MIME类型);(不写也可以?)
  • 2)告示浏览器文件的打开方式是下载:
    response.setHeader("Content-Disposition","attachment;filename=文件名称");
  • 但是,如果下载中文文件,页面在下载时会出现中文乱码或不能显示文件名的情况, 原因是不同的浏览器默认对下载文件的编码方式不同,ie是UTF-8编码方式,而火狐 浏览器是Base64编码方式。所里这里需要解决浏览器兼容性问题,解决浏览器兼容 性问题的首要任务是要辨别访问者是ie还是火狐(其他),通过Http请求体中的一个属性可以辨别其中agent就是请求头User-Agent的值
Paste_Image.png
  • 也就是在tomcat识别时候转成u8(new String(filename.getBytes("ISO8859-1"), "UTF-8")),在客户端识别之前根据不同客户端以不同形式转码(if (agent.contains("MSIE")) {)
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();
    }
  • //response.getOutputStream();
    //response.getWriter();全局可以认为两种是一个不可以同时写(就算有多个servlet)
  • 默认重定向就是编码结束时候

你可能感兴趣的:(web14 HttpServletResponse)