解决Jsp乱码----在Jsp页面中合理的设置pageEncoding、contentType属性

 在Jsp页面中合理的设置pageEncoding、contentType属性,能够解决日常遇见的页面乱码问题,下面就pageEncoding和contentType两种属性的分别,进行简单阐述一下:
   1、pageEncoding是JSP文件默认的编码属性。
   2、contentType中charset是指远程服务器端发送给本地客户端时的内容编码格式。

  在页面传输过程中Jsp要经过三次两种形式的编码:
    第一次编码会用pageEncoding;
    第二次编码会用utf-8至utf-8;
    第三次编码就是由TOMCAT解释输出的网页,用contentType的charset编码。

  第一次编码是Jsp编译成.java文件时,会根据pageEncoding的设定读取Jsp文件,结果是根据指定的编码方案翻译成统一的UTF-8格式的JAVA源码(即所谓的.java),如果pageEncoding设定错了,或是没有设定,出来的就是中文乱码。

  第二次编码是由Javac的JAVA源码到Java byteCode的编译,不管JSP编写时候用的是什么编码方案,经过这个阶段的处理,结果全部是UTF-8的encoding的java源码了。

  JAVAC用UTF-8的encoding读取java源码数据,编译成UTF-8 encoding的二进制码(即.class)形式,这是就JVM对常数字串在二进制码(java encoding)内表达的规范。

  第三次编码是Tomcat(或其的application container)载入和执行阶段二的来的JAVA二进制码,输出的结果,也就是在客户端见到的,这时隐藏在第一次编码和第二次编码的参数contentType就发挥了作用了。

  contentType的常规设定:

  pageEncoding和contentType的预设都是ISO8859-1,只要设定了其中一个, 另一个也就变成一样的了,(TOMCAT4.1.27是如此)。 但这不是一定绝对的, 这要看各自JSPC的处理方式, 然而pageEncoding不等于contentType, 更有利亚洲区的文字 CJKV系JSP网页的开发和展示, 比如:pageEncoding=GB2312并不等于contentType=utf-8。

  然而Jsp文件不像.java,.java在被编译器读入的时候默认采用的是操作系统所设定的locale所对应的编码,比如中国大陆就是GBK,台湾就是BIG5或者MS950。而一般我们不管是在记事本还是在ue中写代码,如果没有经过特别转码的话,写出来的都是本地编码格式的内容。所以编译器采用的方法刚好可以让虚拟机得到正确的资料。

  可是Jsp文件并不是这样的编码,没有默认转码过程,主要我们指了pageEncoding就可以实现正确转码了。

  下面是个简单的示例:

    <%@ page contentType="text/html;charset=utf-8" %>

  基本上绝大多数会打印出乱码,因为输入的“学习Java”是gbk的,但是服务器是否正确抓到“学习Java”还是未知的。。

  试着把上面代码改成:
    <%@ page contentType="text/html;charset=utf-8" pageEncoding="GBK"%>
    传输到服务器后,服务器才能正确抓到“学习Java”,且也不会出现乱码。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值