网站大量收购闲置独家精品文档,联系QQ:2885784924

Java 中文乱码Java 中文乱码.doc

  1. 1、本文档共17页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
java中文乱码 %@ page language=java pageEncoding=UTF-8% %@ page contentType=text/html;charset=iso8859-1% html head title中文问题/title meta http-equiv=Content-Type content=text/html; charset=UTF-8 /head /head body ??? 我是个好人 /body /html 三个地方的编码。 第一个地方的编码格式为jsp文件的存储格式。Eclipse会根据这个编码格式保存文件。并编译jsp文件 ,包括里面的汉字。 第二处编码为解码格式。因为存为UTF-8的文件被解码为iso8859-1,这样 如有中文肯定出乱码。也就 是必须一致。而第二处所在的这一行,可以没有。缺省也是使用iso8859-1的编码格式。所以如果没有 这一行的话,“我是个好人”也会出现乱码。必须一致才可以。 ??? 第三处编码为控制浏览器的解码方式。如果前面的解码都一致并且无误的话,这个编码格式没有关系 。有的网页出现乱码,就是因为浏览器不能确定使用哪种编码格式。因为页面有时候会嵌入页面,导致 浏览器混淆了编码格式。出现了乱码。 2 表单使用Post方式提交后接收到的乱码问题 这个问题也是一个常见的问题。这个乱码也是tomcat的内部编码格式iso8859-1在捣乱,也就是说post 提交时,如果没有设置提交的编码格式,则会以iso8859-1方式进行提交,接受的jsp却以utf-8的方式 接受。导致乱码。既然这样的原因,下面有几种解决方式,并比较。 A 接受参数时进行编码转换 String str = new String(request.getParameter(something).getBytes(ISO-8859-1),utf-8) ; 这样的话,每一个参数都必须这样进行转码。很麻烦。但确实可以拿到汉字。 B 在请求页面上开始处,执行请求的编码代码, request.setCharacterEncoding(UTF-8),把提交内 容的字符集设为UTF-8。这样的话,接受此参数的页面就不必在转码了。直接使用 String str = request.getParameter(something);即可得到汉字参数。但每页都需要执行这句话。 这个方法也就对post提交的有效果,对于get提交和上传文件时的enctype=multipart/form-data是无 效的。稍后下面单独对这个两个的乱码情况再进行说明。 C 为了避免每页都要写request.setCharacterEncoding(UTF-8),建议使用过滤器对所有jsp ??? 进行编码处理。这个网上有很多例子。请大家自己查阅。 3 表单get提交方式的乱码处理方式。 如果使用get方式提交中文,接受参数的页面也会出现乱码,这个乱码的原因也是tomcat的内部编码格 式iso8859-1导致。Tomcat会以get的缺省编码方式iso8859-1对汉字进行编码,编码后追加到url,导致 接受页面得到的参数为乱码/、。 解决办法: A 使用上例中的第一种方式,对接受到的字符进行解码,再转码。 B Get走的是url提交,而在进入url之前已经进行了iso8859-1的编码处理。要想影响这个编码则需要在 server.xml的Connector节点增加useBodyEncodingForURI=true 属性配置,即可控制tomcat对get方式的汉字编码方式,上面这个属性控制get提交也是用 request.setCharacterEncoding(UTF-8)所设置的编码格式进行编码。所以自动编码为utf-8,接受页 面正常接受就可以了。但我认为真正的编码过程是,tomcat又要根据 Connector port=8080 maxThreads=150 minSpareThreads=25 maxSpareThreads=75 enableLookups=false redirectPort=8443 acceptCount=100 debug=0 connectionTimeout=20000 useBodyEncodingForURI=true disableUploadTimeout=true URIEncoding=”UTF-8”/ 里面所设置的URIEncoding=”UTF-8”再进行一次编码,但是由于已经编码为utf-8,再编码也不会有变 化了。如果是从url获取编码,接受页面则是根据U

文档评论(0)

cduutang + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档