编码中的setCharacterEncoding 理解

1、pageEncoding="UTF-8"的作用是设置JSP编译成Servlet时使用的编码。 
2、contentType="text/html;charset=UTF-8"的作用是指定对服务器响应进行重新编码的编码。 
3、request.setCharacterEncoding("UTF-8")的作用是设置对客户端请求进行重新编码的编码。
4、response.setCharacterEncoding("UTF-8")的作用是指定对服务器响应进行重新编码的编码。 
response.setCharacterEncoding("UTF-8")的作用是指定对服务器响应进行重新编码的编码。同时,浏览器也是根据这个参数来对其接收到的数据进行重新编码(或者称为解码)。所以在无论你在JSP中设置response.setCharacterEncoding ("UTF-8")或者response.setCharacterEncoding("GBK"),浏览器均能正确显示中文(前提是你发送到浏览器的数据编码是正确的,比如正确设置了pageEncoding参数等)。

 

对于发送数据,服务器按照response.setCharacterEncoding—contentType—pageEncoding的优先顺序,对要发送的数据进行编码。 

对于接收数据,要分三种情况。一种是浏览器直接用URL提交的数据,另外两种是用表单的GET和POST方式提交的数据。

 

对于表单中POST方式提交的数据,只要在接收数据的JSP中正确request.setCharacterEncoding参数,即将对客户端请求进行重新编码的编码设置成浏览器编码,就可以保证得到的参数编码正确。有写读者可能会问,那如何得到浏览器编码呢?上面我们提过了,在默认请情况下,浏览器编码就是你在响应该请求的JSP页面中response.setCharacterEncoding设置的值。所以对于POST表单提交的数据,在获得数据的JSP页面中request.setCharacterEncoding要和生成提交该表单的JSP页面的 response.setCharacterEncoding设置成相同的值。 

对于URL提交的数据和表单中GET方式提交的数据,在接收数据的JSP中设置request.setCharacterEncoding参数是不行的,因为在Tomcat5.0中,默认情况下使用ISO- 8859-1对URL提交的数据和表单中GET方式提交的数据进行重新编码(解码),而不使用该参数对URL提交的数据和表单中GET方式提交的数据进行重新编码(解码)。要解决该问题,应该在Tomcat的配置文件的Connector标签中设置useBodyEncodingForURI或者 URIEncoding属性,其中useBodyEncodingForURI参数表示是否用request.setCharacterEncoding 参数对URL提交的数据和表单中GET方式提交的数据进行重新编码,在默认情况下,该参数为false(Tomcat4.0中该参数默认为true); URIEncoding参数指定对所有GET方式请求(包括URL提交的数据和表单中GET方式提交的数据)进行统一的重新编码(解码)的编码。 URIEncoding和useBodyEncodingForURI区别是,URIEncoding是对所有GET方式的请求的数据进行统一的重新编码(解码),而useBodyEncodingForURI则是根据响应该请求的页面的request.setCharacterEncoding参数对数据进行的重新编码(解码),不同的页面可以有不同的重新编码(解码)的编码。所以对于URL提交的数据和表单中GET方式提交的数据,可以修改 URIEncoding参数为浏览器编码或者修改useBodyEncodingForURI为true,并且在获得数据的JSP页面中 request.setCharacterEncoding参数设置成浏览器编码。

  • 55
    点赞
  • 149
    收藏
    觉得还不错? 一键收藏
  • 11
    评论
### 回答1: setcharacterencoding是一个HTML标签,用于指定网页的字符编码方式。如果网页的字符编码方式与浏览器不一致,就会出现乱码等问题。因此,正确设置字符编码方式非常重要。如果没有正确设置字符编码方式,就可能会导致网页爆红等问题。 ### 回答2: `setCharacterEncoding`是一个常见的Java开发的方法,用于设置字符编码类型。 `setCharacterEncoding`方法在HttpServletResponse对象使用,用于告诉浏览器以正确的字符编码方式解析服务器响应的文字。 为什么会出现"setCharacterEncoding"爆红的情况呢? 1. 导入错误:在使用`setCharacterEncoding`方法之前,需要先导入相关的类或包,如`javax.servlet.http.HttpServletResponse`,否则会报错。 2. 编码方式不支持:`setCharacterEncoding`方法指定的字符编码类型要与服务器支持的编码方式相匹配。如果设置的字符编码方式不被服务器支持,会导致该方法报错。 3. 方法位置错误:`setCharacterEncoding`方法在HttpServletResponse对象使用,需确保该方法在正确的位置调用。如果将该方法放置在错误的位置,可能会导致编译器报错。 如果遇到"setCharacterEncoding"爆红的情况,可以尝试以下解决方案: 1. 检查导入:确认是否正确导入相关的类或包,如`javax.servlet.http.HttpServletResponse`。 2. 使用支持的编码方式:选择合适的字符编码方式,确保在`setCharacterEncoding`方法设置的编码方式是服务器支持的。 3. 确认方法位置:确认`setCharacterEncoding`方法是否在正确的位置调用,如在发送响应之前执行。 总结,当出现"setCharacterEncoding"爆红时,可以首先检查导入是否正确,然后确认编码方式是否匹配,最后确认方法位置是否正确。通过排除这些可能的问题,可以解决这个问题。 ### 回答3: setCharacterEncoding是HttpServletRequest的一个方法,用于设置请求的字符编码方式。它的作用是告诉服务器请求的数据使用的字符编码方式,这样服务器才能正确地解析请求的数据。 但是,setCharacterEncoding方法可能会出现“爆红”的情况。这是由于开发环境的问题,可能是编译器的版本过低或者开发工具的设置不正确所导致的。常见的开发环境如Eclipse、IntelliJ IDEA等,都会提供一些默认的编码设置,但有时候这些默认设置并不一定能满足项目的需求。 为了解决setCharacterEncoding爆红的问题,可以尝试以下几种方法: 1. 检查编译器或开发工具的设置:确认编译器或开发工具的设置是否正确,特别是编译器的版本是否符合项目要求。 2. 导入正确的包:确保导入的包是正确的,应该导入javax.servlet.http包下的HttpServletRequest类。 3. 更新Servlet API版本:检查项目所依赖的Servlet API版本是否正确,如果版本过低,可能会导致setCharacterEncoding方法无法识别。 4. 重新引入Servlet API依赖:有时候由于项目依赖的问题,可能会导致setCharacterEncoding方法无法被正确识别。可以尝试重新引入Servlet API依赖,或者更新依赖的版本。 5. 切换开发环境:如果以上方法无效,可以尝试切换到其他的开发环境,比如使用另一款IDE进行开发。 总之,解决setCharacterEncoding爆红的问题主要是要确认编译器或开发工具的设置是否正确,以及项目所依赖的Servlet API版本是否正确。通过检查这些方面,一般可以解决这个问题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 11
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值