HttpServletResponse
2020-12-22 15:28
标签:输出 指定 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() 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