web14 HttpServletResponse

2017-09-22  本文已影响0人  路人爱早茶
5秒之后跳转到百度:不常用因为是服务器端写死页面不会有动态效果
response.setHeader("refresh", "5,url=http://www.baidu.com");

1.响应的response的运行流程

Paste_Image.png
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)
(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 href="/web14/fileDownload?filename=a.flv">a.flv</a><br>
参数filename让response获取到文件名字
fileDownload是xml中url
----xml------
<servlet-mapping>
    <servlet-name>FileDownload</servlet-name>
    <url-pattern>/fileDownload</url-pattern>
  </servlet-mapping>
--------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获取会自动被关闭
    }
Paste_Image.png
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();
    }
上一篇下一篇

猜你喜欢

热点阅读