JSP页面中ContentType与PageEncoding的区别

问题背景:项目中一个JSP页面发现加载非常缓慢,页面内容已经全显示完毕了,但发现IE加载并不是[完成]状态,而是[等待]状态(会持续1分多钟),经过一系列排查手段终于发现是由于JSP页面缺少contentType属性中charset的设置导致,加入charset=UTF-8,页面加载慢问题解决。
问题现象:


查了一下JSP页面头中的pageEncoding和contentType的用法,记录下来备忘

1. pageEncoding 只是指明了 JSP 页面本身的编码格式,跟页面显示的编码没有关系;容器在读取(文件)或者(数据库)或者(字符串常量)时将起转化为内部使用的 Unicode,而页面显示的时候将内部的Unicode转换为contentType指定的编码后显示页面内容;如果pageEncoding属性存在,那么JSP页面的字符编码方式就由pageEncoding决定,否则就由contentType属性中的charset决定,如果charset也不存在,JSP页面的字符编码方式就采用默认的ISO-8859-1。
2. contentType 指定了MIME类型和JSP页面回应时的字符编码方式。MIME类型的默认值是“text/html”; 字符编码方式的默认值是“ISO-8859-1”.MIME类型和字符编码方式由分号隔开;
3. 两者关系pageEncoding的内容只是用于jsp输出时的编码,不会作为header发出去的; 是告诉web Server jsp页面按照什么编码输出,即web服务器输出的响应流的编码;

第一阶段是jsp编译成.java,它会根据pageEncoding的设定读取jsp,结果是由指定的编码方案翻译成统一的UTF-8 JAVA源码(即.java).
第二阶段是由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二进制码,输出的结果(也就是Browser)见到的,这时一早隐藏在阶段一和阶段二的参数contentType就发挥了功效

你可能感兴趣的:(java,jvm,tomcat,jsp,IE)