HttpServlletResponse简介

HttpServletResponse是Java web开发中用于向客户端发送响应的对象。本文介绍了它的概述、运行流程、如何设置响应行、响应头和响应体,特别讨论了中文乱码问题的解决方法,以及文件下载的实现,包括如何处理浏览器兼容性问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、HttpServletResponse的概述

web服务器收到客户端的http请求,会针对每一次请求,分别创建一个用于代表请求的request对象、和代表响应的response对象。 
request和response对象即代表请求和响应。我们要获取客户机提交的数据,只需要找request对象就行了;要向客户机发送数据,只需要找response对象就行了。

二、HttpServletResponse的运行流程

 

 

三、Http响应

四、通过response设置响应行

// 设置状态码,302重定向
response.setStatus(302);

五、设置response响应头

// 添加响应头
addHeader(String name, String value)
addIntHeader(String name, int value)
addDateHeader(String name, long date)
// 设置响应头
setHeader(String name, String value)
setIntHeader(String name, int value)
setDateHeader(String name, long date)

【注意】add方法会有多个值,但是set方法只有最有一个值 

重定向:

状态码:302      响应头:location代表重定向的地址

protected void doGet(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
	// TODO Auto-generated method stub
	response.setCharacterEncoding("UTF-8");
	String str1 = "王思伟,我爱你!!!";
	String str2 =  new String(str1.getBytes("iso8859-1"),"UTF-8");
	response.getWriter().write(str2);;
}

六、通过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");就可以解决页面输出中文乱码问题。

response编码和解码的过程分析示意图:

(2)响应头设置字节

ServletOutputStream  getOutputStream()

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

7、案例-完成文件下载

文件下载的实质就是文件拷贝,将文件从服务器端拷贝到浏览器端。所以文件下载需     要IO技术将服务器端的文件使用InputStream读取到,在使用   ServletOutputStream写到response缓冲区中

问题:

          1)什么情况下回文件下载?

              浏览器不能解析的文件就下载

          2)什么情况下需要在服务器端编写文件下载的代码?

             理论上,浏览器可以解析的文件需要编写文件下载代码

protected void doGet(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		// *******文件名称是中文的下载*******

		// 获得要下载的文件的名称
		String filename = request.getParameter("filename");// 美女.jpg
		System.out.println(filename);
		// 解决获得中文参数的乱码----下节课讲
		//filename = new String(filename.getBytes("ISO8859-1"), "UTF-8");// ????.jpg
		System.out.println(filename);
		
		// 获得请求头中的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);
		// 这儿的filenameEncoder是对"美女.jpg"进行针对不同浏览器进行的编码,
		// 不再是"美女.jpg",因为它不识别(导致下载的文件没名称)

		// 获取文件的绝对路径
		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();out.close()可不必写

}

上述代码可以将图片从服务器端传输到浏览器,但浏览器直接解析图片显示在页面上,  而不是提供下载,我们需要设置两个响应头,告知浏览器文件的类型和文件的打开方 式。

  1. 告知浏览器文件的类型:response.setContentType(文件的MIME类型);
  2. 告示浏览器文件的打开方式是下载:

response.setHeader("Content-Disposition","attachment;filename=文件名称");

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

解决乱码方法如下(不要记忆--了解):

 

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");                    

}

response细节点:

     1)response获得的流不需要手动关闭,Tomcat容器会自动关闭

     2)getWriter()和getOutputStream不能同时使用

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值