jsp中影响编码的属性及其设置小结
详解在编码过程中常见的错误和如何避免它们
详解在编码过程中常见的错误和如何避免它们在编码过程中常见错误是不可避免的,但我们可以采取一些措施来减少错误的发生。
下面是一些常见错误以及避免它们的方法。
1.语法错误语法错误是最常见的错误之一,它们通常是由于编码不完整、拼写错误或符号使用错误引起的。
为了避免这些错误,我们可以使用IDE (集成开发环境)来自动检测和纠正语法错误,并且经常检查和重新阅读自己编写的代码以确保没有存在这样的错误。
2.逻辑错误逻辑错误是由于代码中的错误推理或错误的算法实现引起的。
为了避免逻辑错误,我们需要仔细考虑代码中的每一步,并确保算法的正确性。
我们可以使用调试工具来逐步执行代码并观察变量的值,以便找到问题所在。
3.同名变量错误同名变量错误指的是在同一作用域内使用相同名称的变量。
这会导致变量被覆盖,从而导致意想不到的结果。
为了避免这种错误,我们可以使用有意义且唯一的变量名,并定期检查代码以确保没有重复的变量名。
4.空指针错误空指针错误是由于使用未初始化的指针或引用空指针对象而引起的。
为了避免空指针错误,我们应该始终在使用指针之前对其进行初始化,并且在使用指针之前进行有效性检查。
5.越界访问错误越界访问错误是由于对数组或容器进行超出其范围的访问而引起的。
为了避免这种错误,我们需要确保在访问数组或容器之前检查索引的有效性,并且在迭代容器时使用正确的迭代器。
6.重复的代码重复的代码会增加代码维护的难度,并增加引入错误的风险。
为了避免重复的代码,我们可以使用函数或类来封装和复用代码,并使用循环和条件语句来避免编写重复的逻辑。
7.不恰当的数据类型不恰当的数据类型可能导致数据丢失或溢出,进而导致错误的计算结果。
为了避免这种错误,我们应该选择适当的数据类型来存储和处理数据,并使用类型转换来确保数据的正确性。
8.并发错误并发错误是多线程编程中常见的错误之一,它们通常是由于共享资源的不正确使用而引起的。
为了避免并发错误,我们应该使用同步手段(如锁、互斥量、信号量等)来确保对共享资源的互斥访问,并使用原子操作来保证数据的一致性。
Jsp页面中的字符编码方式与乱码解决方法(3)
Jsp页面中的字符编码方式与乱码解决方法(3)Jsp页面中的字符编码方式与乱码解决方法pageencoding="utf-8"contenttype="text/html;charset=utf-8"request.setcharacterencoding("utf-8")response.setcharacterencoding("utf-8")其中前两个只能用于jsp中,而后两个可以用于jsp和servlet中。
1、pageencoding="utf-8"的作用是设置jsp编译成servlet原代码文件时所使用的编码。
jsp在服务器上是要先被编译成servlet的类文件的。
pageencoding="utf-8"的作用就是告诉jsp编译器在将jsp文件编译成servlet为文件时使用的编码。
通常,在jsp内部定义(指在 <%%>块内定义的)的字符串或直接作为html输出(指直接在jsp文件中输写的html中文内容)的字符串出现乱码时,很多都是由于该参数设置错误引起的。
例如,你的jsp文件是以utf-8为编码保存的(在eclipse 选中jsp文件,右键点属性就可以更改保存该jsp的编码方式),而在jsp中却指定pageencoding="gbk"(或不指定时使用操作系统默认的编码方式,即也为gbk),就会引起jsp内部定义的字符串为乱码,这时当我们用文本编辑打开tomcat生成的jsp所对应的servlet类文件时,我们发现就是乱码。
另外,该参数还有一个功能,就是在jsp中不指定contenttype属性,也不使用response.setcharacterencoding方法指定编码方式时,服务器响应的编码方式以及浏览器的编程方式(ie中可以通过菜单“查看-->编码”来看查浏览目前的编码方式)就是此时pageencoding指定的编码方式。
常见编码错误:如何避免和修复
常见编码错误:如何避免和修复编码错误是编程过程中常见且容易出现的问题。
它们经常导致程序运行不正确或输出错误的结果。
为了避免和修复这些错误,我们需要在编写代码时采取一些注意事项和解决方法。
下面是我列举的一些常见编码错误,以及如何避免和修复它们。
1.语法错误语法错误是最常见的编码错误之一。
它们通常是由于拼写错误、缺少或多余的符号或括号造成的。
为了避免语法错误,我们应该养成良好的编码习惯,注意拼写和符号的正确使用。
当程序出现语法错误时,编译器或解释器通常会给出错误提示信息,我们可以根据提示信息来修复错误。
2.运行时错误运行时错误是程序在运行时发生的错误。
它们通常是由于数据类型不匹配、数组越界、除零错误等导致的。
为了避免运行时错误,我们应该在使用变量或数据之前进行合适的类型检查或边界检查。
此外,我们还可以使用异常处理机制来处理运行时错误,以确保程序的稳定性。
3.逻辑错误逻辑错误是程序中最难以察觉和修复的错误之一。
它们通常是由于设计或实现中的错误逻辑导致的。
为了避免逻辑错误,我们应该养成良好的设计和分析习惯,在编写代码之前仔细思考和规划。
此外,我们还可以使用调试工具来帮助我们找到和修复逻辑错误。
4.内存泄漏内存泄漏是指在程序中动态分配的内存没有及时释放,导致内存占用不断增加的情况。
为了避免内存泄漏,我们应该在程序适当的地方释放不再需要的内存,特别是在使用动态内存分配函数(如malloc、new等)分配内存时。
此外,我们还可以使用内存管理工具来检测和修复内存泄漏问题。
5.死锁死锁是多线程程序中常见的问题。
它们通常是由于线程之间的竞争和资源分配不当导致的。
为了避免死锁,我们应该在设计和实现并发程序时遵循良好的并发控制原则。
特别是在使用锁时,要避免出现死锁的情况。
此外,我们还可以使用调试工具来分析和解决死锁问题。
6.输入错误输入错误是编程过程中常见的错误之一。
它们通常是由于用户输入不正确或输入格式不符合要求导致的。
JSP判断题试题及答案
JSP判断题试题及答案1.HTML称为超文本元素语言,它是Hypertext Markup Language的缩写。
[判断题] *对(正确答案)错2.一个HTML文档必须有<head>和<title>元素。
[判断题] *对错(正确答案)3.超级链接不仅可以将文本作为链接对象,也可以将图像作为链接对象。
[判断题] *对(正确答案)错4.表单域一定要放在<form>元素中。
[判断题] *对(正确答案)错5.盒子模型中的top、right、bottom、left属性取值即可以是像素数,也可是百分比,并且只有父容器的position取值为非static值时才有效。
[判断题] *对(正确答案)错6.用户在浏览器中输入http://127.0.0.1:8080/ch2/ch2_1.html即可访问本机上的该页面。
[判断题] *错7.在网页中图形文件与网页文件是分别存储的。
[判断题] *对(正确答案)错8.绝度路径是文件名的完整路径;相对路径是指相对当前网页文件名的路径。
[判断题] *对(正确答案)错9.超级链接<a>标记的target属性取值为链接的目标窗名,可以是parent、blank、self、top。
[判断题] *对错(正确答案)10.当样式定义重复出现的时候,最先定义的样式起作用 [判断题] *对错(正确答案)1.在HTML页面文件中加入JSP脚本元素、JSP标记等就构成了一个JSP页面。
[判断题] *对(正确答案)错2.JSP引擎执行字节码文件的主要任务之一是直接将HTML内容发给客户端。
[判断题] *错3.JSP页面中的变量和方法声明(Declaration)、表达式(Expression)和Java程序片(Scriptlet)统称为JSP标记。
[判断题] *对(正确答案)错4.JSP页面中的指令标记、JSP动作标记统称为脚本元素。
JSP中汉字编码时出现“乱码”的情况及具体解决方案
l4 1
F。 RTu E w 。 R D 。1 。
、 一
关键 词 : J ; S 汉字编 P 码;乱码 问 ; 题 解决
、
集 是几 乎所 有的 中 文 系统和 国际 化 的软 件都 时 ,可以先用数据库 管理系统提供的管理功能 支 持的 中 文字符 集 ,这 也是 最 基本 的 中文字 检查其中的中文数据是否正确。 符集。其编码范 围是高位0 1 0 e xa xf ,低位也 四 J 服务器对中文的支持程度 SP 是 O a l xe x l_ f;汉字从 O b a _ 0 x 0 l开始,结 束于 支 持 J 的 服 务 器 有 很 多 ,这 些 服 务 器 对 SP 0 7 e; xf f 中文的支持 度 又各不相同 ,例如RE N,其 SI G BK 是 GB 3 2 0 的扩 展,是 向 兼 对中文的 支持程度相当的好,而T0MC 对 2 1 8 AT 容的。它包含了 2 9 2个汉字,其 编码范 围是 中文的支持程 度一般。所以 ,在J 编程过程 00 SP 0 8 4 - xe x 10一 f ̄,剔除高位 0 8 的字位。其所 中,要注意J P E 0 x0 S  ̄ 务器对中文的支持程度。 有字符郜 町以一对 一 映射到 Uncd .。 i e2 0 o 找 到 r乱码产生的原因 ,我们在实际编程 GBl0 0 0 0GBK2 8 3 2 0 ( K)在 GBK 的基 过 程中只要综合应用编 程方法 ,就可以解决乱 础 上进 步扩展 _ 宁 ,增加 了藏 、蒙等少数 码的 问题 。 『 汉 民族的宁形。GB 2 从根本上解决 了字位不 K K 实例分析 够 ,宁 形不足的 问题 。它并没有确定所 有的字 下面 以 ・ 个具体的例子来 分析J P S 中乱 码 也 就 足 所 峭的 圈际 化 (lN) 。 各 种 语 言信 启、 形 ,只是规定 了编码 范围 ,留待以 后扩 充。编 解 决 的 方 法 。 【8 BK 兼容 ;四 测 试 平 台 l : 被进一步规 范为 L c l 信息 。处理的底层字 码是变 的 ,其二字节部分与 G o ae ND 20 T MYS 4 QL 字节部 分是扩宽的字形 、字位 ,其编码 范围是 W I OW ¥ 0 0} OM CAT{ 符集变成 了几 包含 了所有字形的 Unc d 。 i e o x l xf 、 l I x 0 0 3 、三 字 测 酞 平 台 2 : 现在大部分具 有 国际化特征 的软件核心t= 首字 节 0 8 O e ¨字 节O 3 x 9 } 节 0 8一0 f、四字 节0 3 — x 9 x i xe x 0 0 3。 W I OW S 0 0 RE I M Y Q 4 ND 2 0 + S N+ S L 符处理都足以 Un c d 为基础的 , 软件运 i e o 所 以 在J P , 管是 从 Uni O e 中 S c d 住 测 试 台 l 无论 怎么 设 置数 据 库 的 下 行时根据 当时的 L cl/ n / o e a e设置 oae I g C d p g a t 编码还是Byt >Un C de 存在问 c c di. 以及 网页的编码 ,都无法 正常显示 e iO 都 n o Ig n 确定桐应的本地字 符编码 设置 ,井依此 处理本 >BY e io e ye { l 台2F,只要 设置M YsQL 地 宁倚 。i处理过程中需要 实现 U io e 和 题 。从Un c d 转为B t ,如果 目标代码集不 f文 ,而 测 吠、 芏 ncd x3 。这 的e od ng,就 町以正常 示中文 。如 果在 nc i 本地宁 ? =的相 互转换 ,甚或以 Un c d 为 存 存对 应的 代码 ,则得 到的 结 果是 0 f _策 1 : io e 32 下需要 示 【 文 ,那 么除 了要 设置 } 1 中f 的两个 不同本地 字?= u 】 = 1 集的相互转换 。这种 是 因为GB2 l 符号 区中的一 些符 号被映 射到 测试 平台 1 些公 共的 符 号编 码 , 由于这 些 符号 出现 任 MY QIt cd, S %n o ig,对数据 库的读写要进行转 1 1 方式 网络环境 i v 被进一 步延伸 ,任 何网络两 S 89 或其它S S BC 字符集中 ,故它们征 换 ,转换代吗如 : 端 的宁衍信息也需要 根据 字符集的设 置睾 换成 I O 8 5 l 专 Un c d 中编码比较 靠前 ,有一 些其有效 位只 /o e p bi tig u l S r Ch n e d (tig s c n a g Co eS rn t) r 可接受的内容。 c pto 位 hr w OEx e i n J v 语 占内部 是用 Un c d 表 示宁符 仃8 ,和汉 字的 编码 莺叠 ,导 致 显示 乱码 。 t o s I aa io e ye i e o ye 的 ,遵守 Unc d V . 。J v 程序无论是 从B t转 为Unc d , 如果B t标识的字符在 io e 2 0 a a rt n c em’ n w S rn (t. eBye (io ti gsrg t ts” s x fd 从 / 丈件 系 统 以 宁 符 流 读 /写 文 件 ,还 是 往 源代码集 不存 ,则得到的结果是O f f ,同 往 8 5 l ) BK” ; 89 ¨, G ) 样存在编码 问题 。 URL 连接 ITMI j I 信息 ,或从 URL 连接 实际编程中 ,J P S r l 程序得到错误 S / e ve t 读取 参数值 ,都会有字符 编码的转换 。这 样做 N d I 题斛决 ! LS ̄ J 虽然增加 r 编程的复 杂度 ,容易引起混淆 ,但 的汉中信息 ,往往是这 两个过程的叠加 ,有时 甚 至是两个过程 叠加后 反复作用的结果 。 JP s 中汉宁编码时 “ 乱码”的问题一直是 却是符合 际化的思想的 。 三 、数据库 自身编码的方式。 JP S 中编 程值得注意的 问题 ,解决的方案也 有 从理论 来说 ,这些根据宁符集设 置而进 在J 编程过 程 【 ,不可避 免要和数据库 很多 。通常需要 考虑的就是从以上三 个方 面找 P s { l 行的卞 符转换 不应 该产生太 多问题 。而事 实是 S q 对症 下药 。 J P 的中文 s 由l F 成用程竹: 的实际运行环境 不【 ,uniO 打 交道 。所 以数据库 自身的编码 方式对J P , 到乱码产 生的原 , 百 I C de 中文的显示起 着决定性 作片。如果在 中文在 写 e c dn 并没有想像中那么复杂,在编程过程 1 n o ig 和 各个本地字符集的 补充、完善 ,以及 系统 或 n 应 用程序 寅现的不规范 ,转码时 出现的问题时 入数据库过程 中 已是乱码 ,那显示的数据毫无 中只要注意卡 是问题就 町避免问题现象的出现 。 交换用的字符编码集 ,如美国的 A C I S I ,中国 的 GB 3 2 8 ,日本的 J 等 ,作 为该 家/ 2 1~ 0 I S 区域 内信启、 处理的基 础,有着统一编码 的重 要 作用。字符编码集按长 度分 为 S BCS ( 字节 字 符集 ) ,DBCS ( 字节字符集 )两 人类。 双 早期的软 什 ( 尤其是操作 系统) ,为 了解决 本 地 符 信息 的计算机处理 ,出 了各种本地 化 版奉 (JO IlN),为 了区分 ,引进 了 LANG, C d p g 等概念 。但是 山于各个本地 字符集 oea e 代码范 围圣毳 ,相 互问信息 交换 困难 ;软件 各 个本地化版本 独立维护成本较 高。因此有必 要 将 本地 化工 怍中 的共性 抽 取 出来 ,作 一 处 致 理 ,将特 州的 本地 化处理内容降低 到最少。这
Javaweb中常见编码乱码问题(一)
Javaweb中常见编码乱码问题(⼀) 最近在看Java web中中⽂编码问题,特此记录下。
本⽂将会介绍常见编码⽅式和Java web中遇到中⽂乱码问题的常见解决⽅法:⼀、常见编码⽅式: 1、ASCII 码 众所周知,这是最简单的编码。
它总共可以表⽰128个字符,0~31是控制字符如换⾏、回车、删 除等,32~126是打印字符,可以通过键盘输⼊并且能够显⽰出来的。
2、ISO-8859-1 它是基于ASCII码基础上扩展的,它总共能表⽰256个字符,涵盖了⼤多数西欧语⾔字符。
详见 该编码不⽀持中⽂,举个中⽂编码栗⼦: 字符串“I am 君⼭”⽤ ISO-8859-1 编码,下⾯是编码结果: 由于ISO-8859-1 是单字节编码且不⽀持中⽂,直接将中⽂字符转成‘3f’, 3f也就是常见的"?"字符 3、GB2312 它是双字节编码,共包含6763个汉字。
4、GBK 汉字内码扩展规范,是基于GB2312上拓展的,加⼊了更多的汉字,能表⽰21003个汉字。
它的编码 是和GB2312兼容的。
也就是说⽤GB2312编码的汉字可以⽤GBK来解码,并且不会乱码。
倒过来就不完 全可以了,因为GB2312描述的汉字⽐GBK少。
5、UTF-16 UTF-16是基于Unicode上定义的,⽤两个字节来表⽰Unicode的转换格式,它采⽤定长的表⽰⽅法, 即不能什么字符都可以⽤两个字节表⽰。
两个字节是16个bit,所以就做UTF-16。
(Unicode 囊括了世界 上所有语⾔,所有语⾔均可通过Unicode来相互翻译,详解) 6、UTF-8 由于UTF-16统⼀采⽤两个字节来表⽰⼀个字符,有很多字符⽤⼀个字节表⽰即可。
所以存储空间放 ⼤了⼀倍,还会增加⽹络传输的流量,所以推出了UTF-8。
UTF-8采⽤了⼀种变长技术,每个编码区域有 不同的字码长度。
通过上⾯介绍和对⽐,对于中⽂字符的处理我想UTF-8是最理想的中⽂编码。
jsp课程总结
jsp课程总结:课程jsp 课程总结范文课程总结怎么写课程总结心得体会篇一:JSP课程总结JSP课程总结1006010101 计算机1班董楠楠在学习这门课之前,JSP对于我来说是一个全新的领域,包括其基础的HTML静态网页的相关知识,数据库方面,服务器的作用都不了解。
一开始难免的失意和紧张,觉得这门课对我来说是一种挑战。
经过一个学期的课程学习以及近期的基于JSP的网盘课程设计,我对这门课终于有了初步的了解,虽然掌握得很肤浅,但内心很兴奋,很欣喜,新的语言入门很难,但我相信在日后的学习中,我会有一定的突破。
JSP的全称是Java Server Pages,它是一种动态网页技术。
我们需要配置的坏境有JDK,Tomcat,还要用到Myeclips这一基础的编程工具。
在学习JSP之前,由于没有网页编程的基础,便学习了HTML这种文本标记语言,自己试着去做简单的静态网站。
后来学做JSP动态网站时,就涉及到了多方面的知识,JSP内部对象及内部对象所涉及的方法,JSP与数据库连接,如何去引用数据库。
这门课更是巩固了JAVA这一基础编程语言,要求对JAVA掌握的要透彻,每门语言要学扎实,深入理解,都要花费很大的功夫,不是容易的事情。
通过以上知识的学习,对开发简单的动态网页有(转载于: 写论文网:jsp课程总结)了些许的眉目,又进一步加深了对JSP的了解。
比如我们此次的课设,设计一个网络硬盘,用户可以再上面上传、下载资料,存储基本信息。
JSP在工作时,首先启动服务器,并且保证应用在服务器上,客户通过浏览器发送请求,服务器接收到请求之后,查找有没有这个文件对应的JAVA文件的对象。
如果没有这个文件,则需要创建(先把JSP文件转换成JAVA文件,编译成.class文件,加载类并创建对象),然后调用对象的相应方法,方法完成对用户的响应,通常输出的是HTML代码,客户端接收到HTML代码,浏览器解析这个代码生成画面。
在网站设计中,处处离不开Servlet,它充当一个控制器,负责封装数据,处理业务,页面分发。
jsp的常用指令有哪些(编译指令动作指令整理)
jsp的常⽤指令有哪些(编译指令动作指令整理)Jsp包含三个编译指令和七个动作指令。
三个编译指令为:page、include、taglib。
七个动作指令为:jsp:forward、jsp:param、jsp:include、jsp:plugin、jsp:useBean、jsp:setProperty、jsp:getProperty。
1、 page指令a. 通常位于jsp页⾯的顶端,同⼀个页⾯可以有多个page指令。
语法格式如下:复制代码代码如下:〈% @page[language="Java"][extends="package.class"][import= "package. class I package. *},…"][session="true I false"][buffer="none I 8kb I size kb" 1[autoFlush="true I false"][isThreadSafe="true I false"][info="text"][errorPage="relativeURL"][contentType="mimeType[ ;charset=characterSet]" I"text/html;charset= "808859-1"][isErrorPage=" true I false"]%〉1)language属性,⼀般情况就是java,代表jsp页⾯使⽤的脚本语⾔。
2)Extends属性,确定 JSP 程序编译时所产⽣的 Java 类,需要继承的⽗类,或者需要实现的接⼝的全限定类名。
1.import属性,⽤来导⼊包,下⾯⼏个包是默认⾃动导⼊的,不需要显式导⼊。
如何解决乱码问题总结
</filter-mapping>
3.URL中的中文问题
对于直接通过在URL中传递中文参数,如“http://localhost/a.jsp?str=中文”这样的get请求,在服务端用request.getParameter("name")时返回的往往是乱码。按以上的做法设置Filter没有用,用request.setCharacterEncoding("gbk")的方式,仍然不管用。
httpServletResponse.setContentType("text/html;charset=gbk")),最好同时在JSP页面的head部分加上<meta http-equiv="Content-Type" content="text/html;charset=gbk">
·在每次要输出中文的地方主动转换编码方式,比如要在页面中输入“中文”二字,就可以用以下方式:
<%
String str="中文";
byte[] tmpbyte=str.getBtyes("ISO-8859-1");
str=new String(tmpbyte);
out.print(str);
%>
2.获取表单提交的数据时的中文乱码问题
%>
<html>
<head>
<title>中文Test</title>
<meta http-equiv="Content-Type" content="text/html;charset=gbk">
第2章 JSP语法基础 2.3 JSP指令元素、2.4 JSP动作元素
第2章 JSP语法基础
2.3 JSP指令元素 2.4 JSP动作元素
JSP开发案例教程
本章内容
01 脚本元素 03 JSP指令元素
02 案例ch2.2_datetime: 时间格式化
04 JSP动作元素
05 案例ch2.5_include: 框架类型网页
06 小结与练习
2.3 JSP指令元素
指定在当前页
4
session
中是否允许 10 isThreadSafe 指定是否线程安全
session操作
5
buffer
指定处理页面 输出内容时的 11 缓冲区大小
autoFlush
是定当缓冲区满时是 否自动清空
指定当前页面
说明当前页面是否为
6
errorPage 运行异常时调 12 isErrorPage 其他页面的异常处理
该JSP动作表示获取或创建一个名称为guess的、属于类com.GuessNumber的、生命周期 为session的对象,详见本书案例ch5.4_guessNumber(猜数游戏)。
JSP开发案例教程
所有的动作元素需要两个属性:
id属性
id属性是动作元素的唯一标识,可以在 JSP页面中被引用。动作元素创建的id值 可以通过PageContext来调用。
可以使用绝对或相对URL。 ✓ tagDir属性指示前缀将被用于标识在WEB-INF/tags目录下的标签文件。
2.4 JSP动作元素
JSP开发案例教程
2.4 JSP动作元素
JSP动作元素
➢ JSP动作利用XML语法格式的标记,来控制JSP容器Servlet引擎的行为。 ➢ 利用JSP动作可以动态地插入文件、重用JavaBean组件、把用户重定向到另外的页面、为Java插件
解决常见的编码错误和bug
解决常见的编码错误和bug在编写和调试代码的过程中,经常会遇到一些常见的编码错误和bug。
这些问题可能会导致程序崩溃、产生错误结果或功能不正常。
为了能够更高效地解决这些问题,以下是一些常见的编码错误和bug以及解决方法。
1.语法错误:这是最常见的错误之一,通常是由于拼写错误、缺少括号、分号或其他基本的语法错误导致的。
解决方法是仔细检查代码,确保拼写正确并添加所需的标点符号。
2.空指针异常:这是由于引用了空对象导致的错误。
解决方法是在使用对象之前,先检查对象是否为null,并在需要时进行适当的处理,例如使用条件语句判断是否为空。
3.数组越界:这是由于访问数组中不存在的索引位置导致的错误。
解决方法是在访问数组时,确保索引值的范围在合法的范围内,可以使用条件语句或循环来检查索引的有效性。
4.逻辑错误:这是由于程序设计上的逻辑错误导致的错误结果或功能不正常。
解决方法是仔细审查代码逻辑,确保算法和条件语句的设计正确,并适时调试代码以查找错误。
5.死循环:这是由于循环条件恒为真或条件永远不满足导致的错误。
解决方法是检查循环条件,确保循环可以正常终止,并通过添加适当的终止条件来修复死循环问题。
6.文件读写错误:这是由于文件路径错误、权限问题或文件格式错误导致的错误。
解决方法是检查文件路径是否正确、确认文件是否存在,并确保程序具有读写文件的权限。
另外,还可以使用异常处理机制来捕获和处理可能出现的文件读写错误。
7.并发问题:这是由于多个线程访问共享资源导致的错误。
解决方法是使用锁或同步机制,以确保同一时间只有一个线程能够访问共享资源,从而避免竞争条件和数据不一致的问题。
8.内存泄漏:这是由于程序中未正确释放不再使用的内存导致的问题。
解决方法是在使用完毕后,确保及时释放不再需要的对象或资源,避免内存泄漏问题的发生。
9.数据类型错误:这是由于不同类型的数据之间进行了不兼容的操作而导致的错误。
解决方法是检查数据类型是否匹配,并在必要时进行类型转换,以确保操作的正确性和合法性。
JSP中的编码设置
web服务器输出的响应流: web Server相应浏览器的输出数据
他们之间的相互影响和作用域,以及先后作用顺序
1. pageEncoding: 只是指明了 JSP 页面本身的编码格式,跟页面显示的编码没有关系;
容器在读取(文件)或者(数据库)或者(字符串常量)时将起转化为内部使用的 Unicode,而页面显示的时候将
JSP中的编码设置:
1. pageEncoding:<%@ page pageEncoding="UTF-8"%>
jsp页面编码: jsp文件本身的编码
2. contentType: <%@ page contentType="text/html; charset=UTF-8"%>
1. pageEncoding的内容只是用于jsp输出时的编码,不会作为header发出去的; 是告诉web Server
jsp页面按照什么编码输出,即web服务器输出的响应流的编码;
2. 第一阶段是jsp编译成.java,它会根据pageEncoding的设定读取jsp,结果是由指定的编码方案翻译
content="text/html; charset=gb2312" />.
5. web页面输入编码: 在设置页面编码<%@page contentType="text/html; chareset=gbk"%>的同时,也就指定了页面的输入编码;如果页面的显示被设置为UTF-8,那么用户所有的页面输入都会按照 UTF-8 编码; 服务器端程序在读 取表单输入之前要设定输入编码; 表单被提交后,浏览器会将表单字段值转换为指定字符集对应的字节值,然后根据 HTTP 标准 URL编码方案对结果字节进行编码.但是页面需要告诉服务器当前页面的编码方式;request.setCharacterEncoding(),能修改Serverlet获取请求的编码,response.setCharacterEncoding(),能修改Serverlet返回结果的编码.
Jsp详解
Jsp详解1.简介2.Jsp的运行原理3.Jsp的语法1.Jsp模板元素2.Jsp中的脚本表达式3.Jsp中的脚本片段4.Jsp的声明5.Jsp注释6.Jsp指令1.首先我们来看一下page指令的用法2.下面在来看一下include指令3.最后来看一下taglib指令7.Jsp中内置的9个隐式对象8.JSP标签库1.jspinclude标签2.jspforward标签3.jspparam或者jspparams标签4.jspuseBean标签jspsetProperty标签jspgetProperty标签9.Jsp中怎么排查错误简介:JSP全称是JavaServer Pages,它和servle技术一样,都是SUN公司定义的一种用于开发动态web资源的技术。
JSP这门技术的最大的特点在于,写jsp就像在写html,但:它相比html而言,html只能为用户提供静态数据,而Jsp技术允许在页面中嵌套java代码,为用户提供动态数据。
相比servlet而言,servlet很难对数据进行排版,而jsp除了可以用java代码产生动态数据的同时,也很容易对数据进行排版。
不管是JSP还是Servlet,虽然都可以用于开发动态web资源。
但由于这2门技术各自的特点,在长期的软件实践中,人们逐渐把servlet作为web应用中的控制器组件来使用,而把JSP技术作为数据显示模板来使用。
其原因为,程序的数据通常要美化后再输出:让jsp既用java代码产生动态数据,又做美化会导致页面难以维护。
让servlet既产生数据,又在里面嵌套html代码美化数据,同样也会导致程序可读性差,难以维护。
因此最好的办法就是根据这两门技术的特点,让它们各自负责各的,servlet只负责响应请求产生数据,并把数据通过转发技术带给jsp,数据的显示jsp来做。
Jsp的运行原理:目标:Web服务器是如何调用并执行一个jsp页面的?Jsp页面中的html排版标签是如何被发送到客户端的?Jsp页面中的java代码服务器是如何执行的?Web服务器在调用jsp时,会给jsp提供一些什么java对象?思考:JSP为什么可以像servlet一样,也可以叫做动态web资源的开发技术?其实Jsp就是一个Servlet,所以我们要先介绍Servlet的相关技术,当我们第一次访问Jsp 的时候,Jsp引擎都会将这个Jsp翻译成一个Servlet,这个文件存放在Tomcat中的work目录中,这里,我们新建一个MyJsp.jsp页面,然后访问以下,我们看一下翻译后的源码:1.<%@ page language="java"import="java.util.*"pageEncoding="utf-8"%>2.3.<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML4.01 Transitional//EN">4.<html>5.<head>6.7.<title>My JSP 'MyJsp.jsp' starting page</title>8.9.</head>10.11.<body>12. This is my JSP page. <br>13.</body>14.</html>1.package org.apache.jsp;2.3.import javax.servlet.*;4.import javax.servlet.http.*;5.import javax.servlet.jsp.*;6.import java.util.*;7.8.public final class MyJsp_jsp extends org.apache.jasper.runtime.HttpJspBase9.implements org.apache.jasper.runtime.JspSourceDependent {10.11.private static final JspFactory _jspxFactory = JspFactory.getDefaultFactory();12.13.private static java.util.List _jspx_dependants;14.15.private javax.el.ExpressionFactory _el_expressionfactory;16.private org.apache.AnnotationProcessor _jsp_annotationprocessor;17.18.public Object getDependants() {19.return _jspx_dependants;20. }21.22.public void _jspInit() {23. _el_expressionfactory = _jspxFactory.getJspApplicationContext(getServletConfig().getServletContext()).getExpressionFactory();24. _jsp_annotationprocessor = (org.apache.AnnotationProcessor) getServletConfig().getServletContext().getAttribute(org.apache.AnnotationProcessor.class .getName());25. }26.27.public void _jspDestroy() {28. }29.30.public void _jspService(HttpServletRequest request, HttpServletResponse response)31.throws java.io.IOException, ServletException {32.33. PageContext pageContext = null;34. HttpSession session = null;35. ServletContext application = null;36. ServletConfig config = null;37. JspWriter out = null;38. Object page = this;39. JspWriter _jspx_out = null;40. PageContext _jspx_page_context = null;41.42.43.try {44. response.setContentType("text/html;charset=utf-8");45. pageContext = _jspxFactory.getPageContext(this, request, response,46.null, true, 8192, true);47. _jspx_page_context = pageContext;48. application = pageContext.getServletContext();49. config = pageContext.getServletConfig();50. session = pageContext.getSession();51. out = pageContext.getOut();52. _jspx_out = out;53.54. out.write("\r\n");55. out.write("\r\n");56. out.write("<!DOCTYPE HTML PUBLIC \"-//W3C//DTD HTML 4.01 Transitional//EN\">\r\n");57. out.write("<html>\r\n");58. out.write(" <head>\r\n");59. out.write(" \r\n");60. out.write(" <title>My JSP 'MyJsp.jsp' starting page</title>\r\n");61. out.write(" \r\n");62. out.write(" </head>\r\n");63. out.write(" \r\n");64. out.write(" <body>\r\n");65. out.write(" This is my JSP page. <br>\r\n");66. out.write(" </body>\r\n");67. out.write("</html>\r\n");68. } catch (Throwable t) {69.if (!(t instanceof SkipPageException)){70. out = _jspx_out;71.if (out != null && out.getBufferSize() != 0)72.try { out.clearBuffer(); } catch (java.io.IOException e) {}73.if (_jspx_page_context != null) _jspx_page_context.handlePageException(t);74. }75. } finally {76. _jspxFactory.releasePageContext(_jspx_page_context);77. }78. }79.}我们看到,这个类继承了org.apache.jasper.runtime.HttpJspBase,要想看到这个类的源码,我1./*2. * Licensed to the Apache Software Foundation (ASF) under one or more3. * contributor license agreements. See the NOTICE file distributed with4. * this work for additional information regarding copyright ownership.5. * The ASF licenses this file to You under the Apache License, Version 2.06. * (the "License"); you may not use this file except in compliance with7. * the License. You may obtain a copy of the License at8. *9. * /licenses/LICENSE-2.010. *11. * Unless required by applicable law or agreed to in writing, software12. * distributed under the License is distributed on an "AS IS" BASIS,13. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.14. * See the License for the specific language governing permissions and15. * limitations under the License.16. */17.18.package org.apache.jasper.runtime;19.20.import java.io.IOException;21.22.import javax.servlet.ServletConfig;23.import javax.servlet.ServletException;24.import javax.servlet.http.HttpServlet;25.import javax.servlet.http.HttpServletRequest;26.import javax.servlet.http.HttpServletResponse;27.import javax.servlet.jsp.HttpJspPage;28.import javax.servlet.jsp.JspFactory;29.30.import piler.Localizer;31.32./**33. * This is the super class of all JSP-generated servlets.34. *35. * @author Anil K. Vijendran36. */37.public abstract class HttpJspBase38.extends HttpServlet39.implements HttpJspPage40.41.42.{43.44.protected HttpJspBase() {45. }46.47.public final void init(ServletConfig config)48.throws ServletException49. {50.super.init(config);51. jspInit();52. _jspInit();53. }54.55.public String getServletInfo() {56.return Localizer.getMessage("");57. }58.59.public final void destroy() {60. jspDestroy();61. _jspDestroy();62. }63.64./**65. * Entry point into service.66. */67.public final void service(HttpServletRequest request, HttpServletResponse response)68.throws ServletException, IOException69. {70. _jspService(request, response);71. }72.73.public void jspInit() {74. }75.76.public void _jspInit() {77. }78.79.public void jspDestroy() {80. }81.82.protected void _jspDestroy() {83. }84.85.public abstract void _jspService(HttpServletRequest request,86. HttpServletResponse response)87.throws ServletException, IOException;88.}好吧,看到了,继承了HttpServlet类,所以说其实Jsp就是一个ServletJsp的语法:1.JSP模版元素2.JSP表达式3.JSP脚本片段4.JSP注释5.JSP指令6.JSP标签7.JSP内置对象8.如何查找JSP页面中的错误Jsp模板元素JSP页面中的HTML内容称之为JSP模版元素。
jsp中文编码乱码的分析与解决
jsp中文编码乱码的分析与解决摘要 jsp技术目前普遍应用于网络编程,java在中文处理方面经常出现乱码现象。
本文从分析各种常见的jsp页面中文乱码产生的原因入手,并给出该乱码的解决方案。
经过多次实践,基本可以解决常见jsp页面常见的中文乱码问题,有着很好的广泛性。
关键词网络编程;中文乱码;jsp页面编码中图分类号tp39 文献标识码a 文章编号1674-6708(2011)57-0183-020引言jsp(java server pages)是由sun公司倡导、许多公司参与一起建立的一种动态网页技术标准,jsp技术采用java作为开发脚本语言,java本身有着很好的跨平台性,但是jsp在结合页面技术后,最使人头疼的一个问题就是不能很好的处理中文乱码问题,在开发过程中带来诸多不便,本文从剖析中文乱码产生的各种原因入手,并给出相应的解决方案。
1中文乱码的根源1)中文的编码很多,在不同的情况下可能有多种不同的二进制值;2)在某些应用中传递数据时,可能把中文转换成其它形式;3)在一个应用系统中,编码之间存在各种各样的转换;4)在转换过程中需要制定编码方式;5)在具体实践过程中,可能忽略或忘记设置编码;6)不同的软件环境其编码设置方式不同也容易导致中文乱码;7)编码工具的多样性以及对编码的模糊认识不清。
2常见的jsp页面中文乱码网上常出现的 jsp/servlet encoding 问题一般都表现在browser 或应用程序端,如:浏览器中看到的 jsp/servlet 页面中的汉字怎么都成了‘?’;浏览器中看到的 servlet 页面中的汉字怎么都成了乱码;java 应用程序界面中的汉字怎么都成了方块;jsp/servlet 页面无法显示gbk 汉字;jsp/servlet 不能接收 form 提交的汉字;jsp/servlet 数据库读写无法获得正确的内容。
3 中文乱码产生原因分析1)在jsp中如果指定了,那么在该jsp中所有用到的数据,如果沒有指定编码,那么这些数据的编码方式为a。
JSP技术中文乱码的原因及解决方法
JSP 技术中文乱码的原因及解决方法杨金花(西安铁路职业技术学院陕西西安710014)摘要:JSP 技术广泛应用于动态网页制作,但在应用中文字符时常常出现乱码。
以前有关JSP 技术中文乱码的研究,只是侧重于对常见的几种中文乱码情况分析,并从网页代码方面进行研究,然后给出相应的代码,缺少对造成中文乱码原因的研究。
本文从造成乱码的根本原因入手进行分析,以JSP 技术工作过程为线索,提出新的研究思路:从开发Java 程序时所涉及的开发环境以及使用的开发工具着手,研究字符的存储与编码的关系,将影响Java 中字符编码的原因分为内因和外因。
研究结果表明,在使用JSP 技术的过程中,中文字符的编码不仅在JSP 工作过程中,会发生编码的转换,而且会因开发环境以及使用开发工具不同,使存储在内存的编码形式发生转换,每种编码之间的转换没有规律。
本文系统地分析了Java 中字符编码的转换,最后针对JSP 中常见的中文乱码情况,给出了相应的解决方法。
关键词:字符编码;中文乱码;JSP 技术;Servlet 中图分类号:TP311文献标识码:A文章编号:1674-6236(2011)01-0025-03The reason and solution of Chinese garbled code in JSP technologyYANG Jin -hua(Xi ’an Railway Vocational Technical College ,Xi ’an 710014,China )Abstract:JSP technology is widely used in the production of dynamic web pages ,but the chinese characters in its application often garbled.Chinese garbled before the JSP technology research ,is focused on several common chinese garbled on the situation analysis ,and researches aspects of the code from the page ,and then gives the corresponding code ,the lack of research into the reasons causes the chinese garbled.This paper analyses from the real causes of the underlying cause garbled.JSP technology researches to the work process for the clues ,puts forward new research ideas :the development of Java programs involved in the development environment and start using the development tools ,storage and encoding of character relationships ,affecting the character encoding in Java is divided into internal and external reasons.The results show that use of JSP technology in the process ,the chinese character code in the JSP course of their work not only will happen coding of the convert ,but also because of development environment ,and use the development tools ,the code stored in memory in different forms.Between each code conversion is not the law.This paper systematically analysed the Java character encoding conversion ,in the end for the JSP common situation in the chinese garbled ,the corresponding solution was given.Key words:character encoding ;chinese garbled ;JSP technology ;ServletJSP ,也就是Java Server Page (Java 服务器网页),是目前市场上主流的分布式应用程序开发平台。
jsp三大指令标记,七大动作标记、详解。
jsp三⼤指令标记,七⼤动作标记、详解。
JSP的基本构成JSP页⾯主要由指令标签,注释,嵌⼊Java代码,JSP动作标签,HTML标记语⾔等五个元素组成。
3个指令标签1 、page指令page指令⽤户定义JSP页⾯中的全局属性,Eg:<%@ page attr1=”value1” atrr2=”value2”.......%>page指令对整个页⾯有效,包括静态的包含⽂件,但page指令不能⽤于被动态包含的⽂件,例如使⽤<jsp:include>包含的⽂件。
在⼀个JSP页⾯中可以使⽤多个page指令,但page指令中的属性只能出现⼀次(import属性除外)。
page指令的常⽤属性如下:(1) language属性该属性⽤于设置JSP页⾯使⽤的语⾔,⽬前只⽀持Java语⾔。
例:<%@ page language=”java” %>(2) extends属性该属性⽤于设置JSP页⾯所继承的Java类,JSP和Servlet都可以继承指定的⽗类,但该属性并不常⽤.(3) import属性该属性⽤于设置JSP所导⼊的类包,JSP页⾯可以嵌⼊Java代码⽚段,这些Java代码在调⽤API时需要导⼊相应的类包。
例: <%@page import=”java.util.*” %>(4) pageEncoding属性该属性⽤于定义JSP页⾯的编码格式,指定的⽂件编码格式。
例:<%@ page pageEncoding=”UTF-8” %>(5) contentType属性该属性⽤于设置JSP页⾯的MIME类型和字符编码,浏览器会根据些解释页⾯。
例:<%@ pagecontentType=”text/html;charset=utf-8” %>(6) session属性该属性⽤于定义JSP页⾯是否使⽤session会话对象,其值是boolean类型,默认值为true. Eg:<%@ page session=”true” %>(7) buffer属性该属性⽤于设置out对象所使⽤的缓冲区⼤⼩,默认⼤⼩是8KB,单位只能是8的倍数。
JSP中文乱码的产生原因及解决方案
JSP中文乱码的产生原因及解决方案在JSP的开发过程中,经常出现中文乱码的问题,可能一直困扰着大家,现在把JSP 开发中遇到的中文乱码的问题及解决办法写出来供大家参考。
首先需要了解一下Java中文问题的由来:Java的内核和class文件是基于unicode的,这使Java程序具有良好的跨平台性,但也带来了一些中文乱码问题的麻烦。
原因主要有两方面,Java和JSP文件本身编译时产生的乱码问题和Java程序于其他媒介交互产生的乱码问题。
首先Java(包括JSP)源文件中很可能包含有中文,而Java和JSP源文件的保存方式是基于字节流的,如果Java和JSP编译成class文件过程中,使用的编码方式与源文件的编码不一致,就会出现乱码。
基于这种乱码,建议在Java文件中尽量不要写中文(注释部分不参与编译,写中文没关系),如果必须写的话,尽量手动带参数-ecoding GBK或-ecoding gb2312或-ecoding UTF-8编译;对于JSP,在文件头加上<%@ page contentType="text/html;charset=GBK"%>或<%@ page contentType="text/html;charset=gb2312"%>基本上就能解决这类乱码问题。
下面是一些常见中文乱码问题的解决方法(下面例子中ecoding采用的是gb2312,也可设为ecoding GBK或ecoding UTF-8):一、JSP页面乱码这种乱码问题比较简单,一般是页面编码不一致导致的乱码,一般新手容易出现这样的问题,具体分以下两种情况:➢未指定使用字符集编码下面的显示页面(display.jsp)就出现乱码:<html><head><title>JSP的中文处理</title><meta http-equiv="Content-Type" content="text/html charset=gb2312"> </head><body><%out.print("JSP的中文处理");%></body>这种乱码的原因是没有在页面里指定使用的字符集编码,JSP页面中出现了中文字符,而默认的ISO-8859-1字符集中无中文字符,解决方法:只要在页面开始地方用下面代码指定字符集编码即可,在JSP页面中指定编码方式(gb2312),和浏览器解码方式设置相同,即在页面的第一行加上:<%@ page contentType="text/html; charset=gb2312"%>,就可以消除乱码了。
JavaScript编码规范
JavaScript编码规范JavaScript作为一种常用的编程语言,编写规范的代码不仅能提高代码的可维护性,还能提升团队合作的效率。
本文将介绍一些常用的JavaScript编码规范。
一、命名规范1. 变量和函数名采用驼峰命名法,首字母小写,例如:```var myVariable;function myFunction() {}```2. 类名采用帕斯卡命名法,首字母大写,例如:```function MyClass() {}```3. 常量名全大写,多个单词之间用下划线连接,例如:```var MAX_COUNT = 10;```4. 私有属性和方法使用下划线开头,例如:```function MyClass() {var _privateVariable;function _privateMethod() {}}```5. 构造函数使用大写字母开头,例如:```function Person() {}var person = new Person();```二、缩进和空格1. 使用2个空格作为一个缩进单位,不使用制表符。
2. 运算符和逗号后面留一个空格,例如:```var result = a + b;```3. 函数名和括号之间不留空格,例如:```function myFunction() {}```4. 左花括号前应加空格,例如:```if (condition) {// do something}```三、空行1. 在函数之间和代码块之间使用一个空行进行分隔。
2. 函数内部逻辑相对独立的部分可以使用空行进行分隔,提高可读性。
四、注释1. 单行注释使用`//`,在注释符号后空一格,例如:```// This is a comment```2. 多行注释使用`/* */`,例如:```/*This is amulti-linecomment*/```3. 在函数或者复杂逻辑前使用多行注释进行简要说明功能或者实现思路。
js对字符串进行编码的方法总结(推荐)
js对字符串进⾏编码的⽅法总结(推荐)在⽤javascript对URL字符串进⾏编码中,虽然escape()、encodeURI()、encodeURIComponent()三种⽅法都能对⼀些影响URL完整性的特殊字符进⾏过滤。
但后两者是将字符串转换为UTF-8的⽅式来传输,解决了页⾯编码不⼀⾄导致的乱码问题。
例如:发送页与接受页的编码格式(Charset)不⼀致(假设发送页⾯是GB2312⽽接收页⾯编码是UTF-8),使⽤escape()转换传输中⽂字串就会出现乱码问题。
以下是JS下对URL进⾏编/解码的各种⽅法:1、escape ⽅法:返回⼀个可在所有计算机上读取的编码 String 对象。
function escape(charString : String) : String不会被此⽅法编码的字符: @ * / +说明:escape ⽅法返回⼀个包含 charstring 内容的字符串值(Unicode 格式)。
所有空格、标点、重⾳符号以及任何其他⾮ ASCII 字符都⽤ %xx 编码替换,其中 xx 等于表⽰该字符的⼗六进制数。
例如,空格返回为“%20”。
(字符值⼤于 255 的字符以 %uxxxx 格式存储。
)注意:escape ⽅法不能⽤来对“统⼀资源标识符”(URI) 进⾏编码。
对其编码应使⽤ encodeURI 和encodeURIComponent ⽅法。
2、encodeURI ⽅法:返回编码为有效的统⼀资源标识符 (URI) 的字符串。
function encodeURI(URIString : String) : String不会被此⽅法编码的字符:! @ # $ & * ( ) = : / ; ? + '说明:encodeURI ⽅法返回⼀个已编码的 URI。
如果将编码结果传递给 decodeURI,则将返回初始的字符串。
encodeURI 不对下列字符进⾏编码:“:”、“/”、“;”和“?”。
JS中URL编码参数(UrlEncode)
JS中URL编码参数(UrlEncode)⽹上有很多⽂字作品写涉及在JS中呈现类似UrlEncode功能时都是⾃定义参数来呈现,其实JS中本⾝就有那样的参数。
参数parameter由于⽤类似URL的形式传过去,所以别直接就那样赋值以下是对变量值的URL编码总结:意见⽤encodeURIComponent() , GET 和POST⽅法都能够发送过去Java编程script中存在⼏种对URL字符串停⽌编码的窍门:escape(),encodeURI(),以及encodeURIComponent()。
这⼏种编码所起的功能各不相同。
escape() 窍门:采⽤ISO Latin字符集对指定的字符串停⽌编码。
所有的空格符、标点符号、特殊字符以及更多有联系⾮ASCII字符都将被转化成%xx各式的字符编码(xx等于该字符在字符集表⾥⾯的编码的16进制数字)。
⽐如,空格符对应的编码是%20。
不会被此窍门编码的字符: @ * / +encodeURI() 窍门:把URI字符串采⽤UTF-8编码各式转化成escape各式的字符串。
不会被此窍门编码的字符:! @ # $& * ( ) = : / ; ? + 'encodeURIComponent() 窍门:把URI字符串采⽤UTF-8编码各式转化成escape各式的字符串。
与encodeURI()相⽐,那个窍门将对更多的字符停⽌编码,⽐如 / 等字符。
所以假如字符串⾥⾯包含了URI的⼏个部份的话,别⽤那个窍门来停⽌编码,否则 / 字符被编码之后URL将呈现错误。
不会被此窍门编码的字符:! * ( ) '因此,对于汉⽂字符串来说,假如不期望把字符串编码各式转化成UTF-8各式的(⽐如原页⾯和⽬的页⾯的charset是⼀致的时候),只需求应⽤escape。
假如你的页⾯是GB2312或者更多有联系的编码,⽽接受参数parameter的页⾯是UTF-8编码的,就要采⽤encodeURI或者encodeURIComponent。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
contentType,pageEncoding,charset,setChar acterEncoding
一、名词解释及其作用
1. contentType: <%@ page contentType="text/html; charset=UTF-8"%>
2. pageEncoding:<%@ page pageEncoding="UTF-8"%>
3. html页面charset:<META http-equiv="Content-Type"
content="text/html; charset=UTF-8">
4.
setCharacterEncoding:request.setCharacterEncoding(),response.setChara cterEncoding()
5. setContentType:response.setContentType()
6. setHeader: response.setHeader()
7. jsp页面编码: jsp文件本身的编码
8. web页面显示编码:jsp的输出流在浏览器中显示的编码
9. web页面输入编码: 输入框输入的字体编码
10. web服务器输入的请求流: web Server相应浏览器的请求数据
11. web服务器输出的响应流: web Server相应浏览器的输出数据
二、他们之间的相互影响和作用域,以及先后作用顺序
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类型和字符编码方式由分号隔开;
三、 pageEncoding和contentType的关系:
1. pageEncoding的内容只是用于jsp输出时的编码,不会作为header 发出去的; 是告诉web Server
jsp页面按照什么编码输出,即web服务器输出的响应流的编码;
2. 第一阶段是jsp编译成.java,它会根据pageEncoding的设定读取jsp,结果是由指定的编码方案翻译
成统一的UTF-8 JAVA源码(即.java).
3. 第二阶段是由JAVAC的JAVA源码至java byteCode的编译,不论JSP 编写时候用的是什么编码方案,
经过这个阶段的结果全部是UTF-8的encoding的java源码.JAVAC 用UTF-8的encoding读取
java源码,编译成UTF-8 encoding的二进制码(即.class),这是JVM对常数字串在二进制码
(java encoding)内表达的规范.
4. 第三阶段是Tomcat(或其的application container)载入和执行阶段二的来的JAVA二进制码,
输出的结果,也就是在客户端见到的,这时隐藏在阶段一和阶段二的参数contentType就发挥了功效
四、和contentType效果一样的设置方式还有 html页面charset, response.setCharacterEncoding(),response.setContentType(),response.se tHeader()。
response.setContentType(),response.setHeader();优先级最好,其次是response.setCharacterEncoding();再者是<%@page
contentType="text/html; chareset=gbk"%>,最后是<meta
http-equiv="content-type" content="text/html; charset=gb2312" />.
五、 web页面输入编码:
在设置页面编码<%@page contentType="text/html; chareset=gbk"%>的同时,也就指定了页面的输入编码;
如果页面的显示被设置为UTF-8,那么用户所有的页面输入都会按照UTF-8 编码; 服务器端程序在读取表单输入之前要设定输入编码;
表单被提交后,浏览器会将表单字段值转换为指定字符集对应的字节值,然后根据 HTTP 标准URL编码方案对结果字节进行编码.但是页面需要告诉服务器当前页面的编码方式; request.setCharacterEncoding(),能修改Serverlet获取请求的编码,response.setCharacterEncoding(),能修改Serverlet返回结果的编码.。