💎一站式轻松地调用各大LLM模型接口,支持GPT4、智谱、星火、月之暗面及文生图 广告
[TOC] # HttpServletResponse概述 doGet()/doPost(),这些方法都有两个参数,一个为代表请求的request和代表响应response。 service方法中的response的类型是ServletResponse,而doGet/doPost方法的response的类型是HttpServletResponse,HttpServletResponse是ServletResponse的子接口,功能和方法更加强大,今天我们学习HttpServletResponse。 # 设置响应行 设置响应行的状态码 ~~~ setStatus(int sc) ~~~ # 设置响应头 ~~~ 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) ~~~ 其中,add表示添加,而set表示设置 # 设置响应体 (1)**响应体设置文本** ~~~ PrintWriter getWriter() ~~~ 获得字符流,通过字符流的write(String s)方法可以将字符串设置到response 缓冲区中,随后Tomcat会将response缓冲区中的内容组装成Http响应返回给浏览器端。 关于设置中文的乱码问题 原因:response缓冲区的默认编码是iso8859-1,此码表中没有中文,可以通过 response的 设置response的编码 ~~~ setCharacterEncoding(String charset) ~~~ 但我们发现客户端还是不能正常显示文字 原因:我们将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响应返回给浏览器。 # 文件下载 文件下载的实质就是文件拷贝,将文件从服务器端拷贝到浏览器端。所以文件下载需 要IO技术将服务器端的文件使用InputStream读取到,在使用 ServletOutputStream写到response缓冲区中 ![](https://box.kancloud.cn/46669cfab55fb5229147b4bff975b8e6_431x205.png) 上述代码可以将图片从服务器端传输到浏览器,但浏览器直接解析图片显示在页面上, 而不是提供下载,我们需要设置两个响应头,告知浏览器文件的类型和文件的打开方 式。 1)告知浏览器文件的类型:response.setContentType(文件的MIME类型); 2)告示浏览器文件的打开方式是下载: response.setHeader("Content-Disposition","attachment;filename=文件名称"); ![](https://box.kancloud.cn/cd0fc6747e5bdcd1df50ad8ea3c4947b_453x255.png) 但是,如果下载中文文件,页面在下载时会出现中文乱码或不能显示文件名的情况, 原因是不同的浏览器默认对下载文件的编码方式不同,ie是UTF-8编码方式,而火狐 浏览器是Base64编码方式。所里这里需要解决浏览器兼容性问题,解决浏览器兼容 性问题的首要任务是要辨别访问者是ie还是火狐(其他),通过Http请求体中的一 个属性可以辨别 ![](https://box.kancloud.cn/b9b2d0b01d427d491217e632f09cf246_439x30.png) 解决乱码方法如下: ~~~ if (agent.contains("MSIE")) { // IE浏览器 filename = URLEncoder.encode(filename, "utf-8"); filename = filename.replace("+", " "); } else if (agent.contains("Firefox")) { // 火狐浏览器 BASE64Encoder base64Encoder = new BASE64Encoder(); filename = "=?utf-8?B?" + base64Encoder.encode(filename.getBytes("utf-8")) + "?="; } else { // 其它浏览器 filename = URLEncoder.encode(filename, "utf-8"); } ~~~ 其中agent就是请求头User-Agent的值 ![](https://box.kancloud.cn/d2eee56ec5aed2514af4bf16992ed47a_484x298.png)