您的位置:首页 > 其它

解决乱码的几个常用方法的联系与区别:

2010-12-20 22:19 260 查看
setContentType和setCharacterEncoding间的区别:

request.setCharacterEncoding()是设置从request中取得的值或从数据库中取出的值
response.setContentType("text/html;charset=gb2312")是设置页面中为中文编码
前者是设置动态文字(参数,数据库),后者设置页面静态文字

response.setContentType指定 HTTP 响应的编码,同时指定了浏览器显示的编码.
response.setCharacterEncoding设置HTTP 响应的编码,如果之前使用response.setContentType设置了编码格式,则使用response.setCharacterEncoding指定的编码格式覆盖之前的设置.与response.setContentType相同的是,调用此方法,必须在getWriter执行之前或者response被提交之前.

request.setCharacterEncoding()与字符串的方法区别:

1、request.setCharacterEncoding 可以解决中文乱码问题,但它只对post方法有效。
2、①,两者的处理过程不一样。String title=request.getParameter("title"); 是直接从request获得字符串,字符集是系统默认的字符集。
而title = new String(title.getBytes("ISO8859-1"),"GBK");
第一步,是title.getBytes("ISO8859-1"),使用给定的 "ISO8859-1"字符集 将此字符串title 编码到 byte 序列,并将结果存储到新的 byte 数组。然后再通过使用指定的 "GBK"字符集解码指定的 byte 数组,构造一个新的 String。

②,title = new String(title.getBytes("ISO8859-1"),"GBK");可以在一定程度上防止出现乱码问题。而String title=request.getParameter("title");却不能。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐