请求乱码产生的原因
浏览器用什么码表来打开表单页面就用什么编码来发送数据。当前我们的注册页面指定了用
utf-8 来打开。
这就决定了浏览器是用 utf-8 打开的页面,浏览器在提交表单时是用 utf-8 编码的。
而 tomcat 默认情况下会使用 iso8859-1 来进行解码。
我们知道全世界的码表都兼容 iso8859-1,所以英文处理是没有问题的。
但是 iso8859-1 中并没有中文,iso8859-1 对于无法处理的字节都使用?替代,所以我们看
到的都是?。
如何来处理 get 请求产生的乱码?
由于客户端发送时使用的是 utf-8 编码而服务器用 iso8859-1 解码造成了乱码,虽然字符已
经乱掉了,但底层的字节仍然是正确的,我们只要将乱码字符 getBytes(“iso8859-1”)
转换为字节,就是正确的字节,再将这些字节 new String(bytes,“utf-8”)按照正确的码
表编码,就可以转换回正确的字符了。从而解决了乱码
如何处理响应乱码
*** 通知服务器在响应数据时,使用utf-8编码
- 也能通知浏览器使用utf-8接收服务器发送的数据 /
response.setContentType( “text/html;charset=utf-8” );
PrintWriter out = response.getWriter();
out.write( “你好” );*
通过 response.setHeader(“Content-Type”, “text/html;charset=utf-8”)方法,通知服务
器发送数据时的码表;通过 response.setCharacterEncoding(“utf-8”)方法,通知浏览器
解析时使用的码表。两码相同就不会有乱码了。
response 提供了 setContentType(“text/html;charset=UTF-8”)快捷方法,在它的底层,
会同时做上面两件事,所以可以一行代码解决 response 产生的乱码问题。
Request 生命周期
request 对象的生命周期是针对一个客户端(一个浏览器应用程序)的一次请求,当请求完毕
之后,request 里边的内容也将被释放,一个请求开始时创建,请求结束后销毁
request.getParameter() 和 request.getAttribute()
的区别?
a、request.getParameter()获取的类型是 String;
request.getAttribute()获取的类型是 Object
b、request.getPrameter()获取的是 POST/GET 传递的参数值和 URL 中的参数;
request.getAttribute()获取的是对象容器中的数据值/对象
c、request.setAttribute()和 request.getAttribute()可以发送、接收对象;
request.getParamter()只能接收字符串,官方不开放 request.setParamter()(也
就是没有这个方法)
setAttribute()和 getAttribute()的传参原理:
setAttribute()是应用服务器把这个对象放在该页面所对应的一块内存中去,当你的
页面服务器重定向到另外一个页面时,
应用服务器会把这块内存拷贝到另一个页面所对应的那块内存中。这个就可以通过
getAttribute()获取到相应的参数值或者对象。