JSP要经过两次的“编码”,第一阶段会用pageEncoding,第二阶段会用utf-8至utf-8,第三阶段就是由Tomcat出来的网页, 用的是contentType
第一阶段是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,
<%@ page contentType="text/html;charset=utf-8" %>
记得老师上课讲的时候遇到了下面这种情况 他的处理办法是把utf-8改成了gbk,
<%@ page contentType="text/html;charset=gbk" %>
貌似就是利用了随便改变其中一个另一个就跟着变的原理吧。实际上正规的该法应该是
<%@ page contentType="text/html;charset=utf-8" pageEncoding="GBK"%>
但是如果改成了这样,在服务器端收到的获取的中文不是乱码,但是在客户端打开的还是乱码,因为charset=utf-8" 中charset指定了,输出到客户端的是utf-8的编码,所以想正规的该法应该改成
<%@ page contentType="text/html;charset=gbk" pageEncoding="GBK"%>
貌似这样写,还不如
<%@ page contentType="text/html;charset=gbk" %>
简单呢, 看来以后自己还是用 这种简单的写法吧!
纯属个人自学的理解。如果错误还望指出
分享到:
相关推荐
### jsp中charset和pageEncoding知识点详解 #### 一、基本概念 在Web开发中,尤其是在使用JavaServer Pages (JSP) 进行网页开发时,经常会遇到字符集(Charset)与页面编码(Page Encoding)的相关问题。这两个...
在Web开发中,尤其是使用Java Server Pages(JSP)进行页面渲染时,经常会遇到`pageEncoding`和`contentType`属性,并且它们都涉及到`charset`这一概念。正确理解这些属性及其之间的差异对于确保网页内容能够被正确...
在Java Server Pages(JSP)技术中,`pageEncoding`和`contentType`是两个重要的属性,它们分别控制着JSP页面的编码方式以及输出内容的类型。了解这两个属性的区别对于正确处理中文和其他非ASCII字符集非常重要。 #...
在JSP(Java Server Pages)开发中,pageEncoding和contentType是两个非常重要的属性,它们对于网页的显示和数据处理起着关键作用。理解这两个属性的区别和联系是确保网页内容正确显示和数据安全传输的基础。 首先...
jsp编码 jsp乱码解决方案 ...通过设置pageEncoding参数、contentType参数、request.setCharacterEncoding方法和response.setCharacterEncoding方法等,可以解决jsp页面中的乱码问题,提高Web应用程序的用户体验。
charset=GB18030" pageEncoding="GB18030"%> 2. 将各种编码方式都改成 GB18030。 3. 保存 JSP 文件。 这样,在 JSP 文件中,中文字符将被正确显示。 其他相关知识点: * JSP 中的中文乱码问题解决方法 * JSP 中...
在JavaServer Pages (JSP) 技术中,`pageEncoding` 和 `contentType` 是两个非常重要的属性,它们直接影响到JSP页面的编码处理和内容的传输。理解这两个属性的区别和作用对于避免乱码问题至关重要。 `pageEncoding`...
- `pageEncoding`属性:此属性用于定义JSP文件本身的编码,当JSP被解析和转换为Java源代码时,JSP引擎会根据此设置读取和处理文件。在示例中,`pageEncoding="utf-8"`表示JSP文件使用UTF-8编码,这是推荐的编码方式...
需要注意的是,为了保证一致性和避免乱码,建议让 `pageEncoding` 和 `contentType` 中的 `charset` 参数保持一致。 #### 2. 文件的BOM 有些编码方式(如UTF-8)会在文件头部加入BOM(Byte Order Mark)。BOM的...
综上所述,解决JSP中的中文乱码问题需要从多个方面入手,既要确保服务器端和客户端的数据交互过程中的编码一致性,又要保证各个组件间的编码设置协调一致。只要按照以上介绍的方法逐一排查和调整,便可以有效地解决...
在JSP文件中明确指定pageEncoding可以避免编译时的乱码问题。 3. **HTTP请求的编码** - GET和POST请求中的参数编码依赖于浏览器。GET请求中,浏览器会先按照HTML页面的编码(通常是UTF-8)对参数进行URL编码,然后...
在jsp文件中,存在三个地方的编码格式:jsp文件的存储格式、解码格式和控制浏览器的解码方式。如果这三个地方的编码格式不一致,将会出现乱码。 1. 最基本的乱码问题 最基本的乱码问题是由于jsp文件的存储格式和...
在JSP文件中,可以通过声明`<%@ page language="java" pageEncoding="UTF-8" %>`, 这一行指定了JSP文件本身的编码格式为UTF-8,即文件存储的编码。如果没有其他指定,则JSP编译后的Servlet也会使用该编码格式来读取...
本文将深入探讨JSP和Servlet中的几个关键编码设置的作用及原理,帮助开发者更好地理解和解决实际开发中遇到的编码问题。 #### 二、主要编码设置及其作用 ##### 1. `pageEncoding="UTF-8"` - **作用**:`...
在Java服务器页面(JSP)开发中,页面跳转是一个常见的需求,特别是在处理用户交互和信息验证时。`jsp:forward`元素是JSP中的一种动作标签,用于将请求转发到另一个页面,而不是生成一个新的HTTP请求。这在处理用户...
在 jsp 页面中,pageEncoding 指的是 jsp 文件本身在本地保存时的编码方式,而 contentType 的 charset 是指服务器发送网页内容给客户端时所使用的编码。因此,在 jsp 页面中需要设置 pageEncoding 和 contentType ...
为了解决这些问题,我们需要深入理解JSP中的`contentType`和`pageEncoding`这两个关键属性。 首先,`contentType`属性是用于定义JSP生成的HTML页面在浏览器中的字符编码。它告诉浏览器如何解析和显示接收到的内容。...
- 确保JSP页面的`charset`和`pageEncoding`属性设置为同一编码格式,通常推荐使用"UTF-8"。 示例代码: ```jsp ; charset=UTF-8" pageEncoding="UTF-8" %> ``` 2. **解决请求参数乱码**: - 当表单提交数据时...
在JavaServer Pages(JSP)技术中,进行加法运算是一项基本操作,广泛应用于各种网页交互和数据处理。JSP是一种动态网页开发技术,它允许开发者在HTML、XML或者其他标记语言中嵌入Java代码,从而实现服务器端的逻辑...
### JSP和Servlet中的中文乱码问题根源 中文乱码问题通常源于字符编码不一致或配置错误。在Web应用中,数据流经多个环节,包括客户端浏览器、服务器端的请求响应处理、数据库交互等。每个环节都可能有自己的默认...