HttpServletResponse

2020-12-22 15:28

阅读:746

标签:输出   指定   html   编码方式   att   客户   一个   firefox   agent   

概念

我们在创建Servlet时会覆盖service()方法,或doGet()/doPost(),这些方法都有两个参数,一个为代表请求的request和代表响应response。

service方法中的response的类型是ServletResponse,而doGet/doPost方法的response的类型是HttpServletResponse,HttpServletResponse是ServletResponse的子接口,功能和方法更加强大

流程

技术图片

 

响应

1.响应行

2.响应头

3.响应体

设置响应

1.setStatus(状态码)                     设置状态码

2.addHeader(响应体名称,String类型内容)                  添加指定的内容的指定响应头

3.addIntHeader(响应体名称,Int类型内容)                  添加指定的内容的指定响应头

4.addDateHeader(响应体名称,毫秒值)                  添加指定的内容的指定响应头

5.setHeader(响应体名称,String类型内容)                  将指定响应头设置为指定内容

6.setIntHeader(响应体名称,Int类型内容)                将指定响应头设置为指定内容

7.setDateHeader(响应体名称,毫秒值)                 将指定响应头设置为指定内容

8.getWrite()                                            

获得字符流,通过字符流的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-8response.setContentType("text/html;charset=UTF-8"); 上面的代码不仅可以指定浏览器解析页面时的编码,同时也内含 setCharacterEncoding的功能,所以在实际开发中只要编写 response.setContentType("text/html;charset=UTF-8");就可以解决页面输出中文乱码问题。
9.getOutputStream()                              获得字节流,通过该字节流的write(byte[] bytes)可以向response缓冲区中写入字 节,在由Tomcat服务器将字节内容组成Http响应返回给浏览器。
文件下载
需要浏览器提供下载而不是直接将内容解析在浏览器上因此需要设置两个响应头

1)告知浏览器文件的类型:response.setContentType(文件的MIME类型);

2)告示浏览器文件的打开方式是下载:response.setHeader("Content-Disposition","attachment;filename=文件名称");

如果下载中文文件,页面在下载时会出现中文乱码或不能显示文件名的情况, 原因是不同的浏览器默认对下载文件的编码方式不同,ie是UTF-8编码方式,而火狐 浏览器是Base64编码方式。所里这里需要解决浏览器兼容性问题,解决浏览器兼容 性问题的首要任务是要辨别访问者是ie还是火狐(其他),通过Http请求体中的一 个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");

}

细节

1.response获得的流不需要手动关闭,web容器(tomcat容器)会帮助我们关闭,

2.getWriter和getOutputStream不能同时调用

3.重定向语句一般作为终结代码

重定向

被请求者无法实现请求时,将能够实现该请求者以响应的方式返回给客户端,客户端再向后者发送请求

需要302状态码和location响应头(重定向后的地址)配合使用

HttpServletResponse

标签:输出   指定   html   编码方式   att   客户   一个   firefox   agent   

原文地址:https://www.cnblogs.com/liu-666/p/13984303.html


评论


亲,登录后才可以留言!