`
独孤不求败
  • 浏览: 26221 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

常用编码总结

    博客分类:
  • java
阅读更多
1.编码区别:
iso8859-1: 通常叫做Latin-1,属于单字节编码,最多能表示的字符范围是0-255,应用于英文系列。比如,字母a的编码为0x61=97。

UTF-8:utf编码兼容iso8859-1编码,不是固定字长编码的,而是一种变长的编码方式,每一个字符的长度从1-6个字节不等:
数字和字符一般占1个字节,
utf8字符集中一个中文字符占几个字节:
占2个字节的:〇
占3个字节的:基本等同于GBK,含21000多个汉字
占4个字节的:中日韩超大字符集里面的汉字,有5万多个

Unicode:这是最统一的编码,可以用来表示所有语言的字符,而且是定长双字节(也有四字节的)编码,包括英文字母在内。所以可以说它是不兼容iso8859-1编码的,也不兼容任何编码。不过,相对于iso8859-1编码来说,uniocode编码只是在前面增加了一个0字节,比如字母a为"00 61"。
Unicode只是一个编码规范,目前实际实现的unicode编码只要有三种:UTF-8,UCS-2和UTF-16,三种unicode字符集之间可以按照规范进行转换。
    最初的unicode编码是固定长度的,16位,也就是2两个字节代表一个字符,这样一共可以表示65536个字符。显然,这样要表示各种语言中所有的字符是远远不够的。Unicode4.0规范考虑到了这种情况,定义了一组附加字符编码,附加字符编码采用2个16位来表示,这样最多可以定义1048576个附加字符,目前unicode4.0只定义了45960个附加字符。
需要说明的是,定长编码便于计算机处理(注意GB2312/GBK不是定长编码),而unicode又可以用来表示所有字符,所以在很多软件内部是使用unicode编码来处理的,比如java。

GBK/GB2312: GBK兼容gb2312编码;二者兼容iso8859-1编码;编码表示汉字,是双字节编码,而英文字母数字和iso8859-1一致占单字节;
其中gbk编码能够用来同时表示繁体字和简体字,而gb2312只能表示简体字,gbk是兼容gb2312编码的。

2java对字符的处理
在java应用软件中,会有多处涉及到字符集编码,有些地方需要进行正确的设置,有些地方需要进行一定程度的处理。

2.1 getBytes(charset)
       这是java字符串处理的一个标准函数,其作用是将字符串所表示的字符按照charset编码,并以字节方式表示。注意字符串在java内存中总是按unicode编码存 储的。比如"中文",正常情况下(即没有错误的时候)存储为"4e2d 6587",如果charset为"gbk",则被编码为"d6d0 cec4",然后返回字节"d6 d0 ce c4"。如果charset为"utf8"则最后是"e4 b8 ad e6 96 87"。如果是"iso8859-1",则由于无法编码,最后返回 "3f 3f"(两个问号)。

2.2 new String(charset)
        这是java字符串处理的另一个标准函数,和上一个函数的作用相反,将字节数组按照charset编码进行组合识别,最后转换为unicode存储。参考上述getBytes的例子,"gbk" 和"utf8"都可以得出正确的结果"4e2d 6587",但iso8859-1最后变成了"003f 003f"(两个问号)。因为utf8可以用来表示/编码所有字符,所以new String( str.getBytes( "utf8" ), "utf8" ) === str,即完全可逆。

2.3 setCharacterEncoding()
该函数用来设置http请求或者相应的编码。

       对于request,是指提交内容的编码,指定后可以通过getParameter()则直接获得正确的字符串,如果不指定,则默认使用iso8859-1编码,需要进一步处理。

       参见下述"表单输入"。值得注意的是在执行setCharacterEncoding()之前,不能执行任何getParameter()。java doc上说明:This method must be called prior to reading request parameters or reading input using getReader()。而且,该指定只对POST方法有效,对GET方法无效。分析原因,POST方法在执行第一个getParameter()的时候,java将会按照编码分析所有的提交内容,而后续的getParameter()不再进行分析,所以setCharacterEncoding()无效。而对于GET方法提交表单是,提交的内容在URL中,一开始就已经按照编码分析所有的提交内容,setCharacterEncoding()自然就无效。

       注意:iso-8859-1是JAVA网络传输使用的标准字符集,而gb2312是标准中文字符集,当你作出提交表单等需要网络传输的操作的时候,就需要把 iso-8859-1转换为gb2312字符集显示,否则如果按浏览器的gb2312格式来解释iso-8859-1字符集的话,由于2者不兼容,所以会 是乱码.
  
  
规律:
utf-8编码可以用gbk和iso8859-1解码后编回去

gbk编码后只能用iso8859-1解码后编回去



String code = "中国";
// 编码
byte[] utf = code.getBytes("utf-8");
byte[] gbk = code.getBytes("gbk");
System.out.println("utf-8编码:" + Arrays.toString(utf));//[-28, -72, -83, -27, -101, -67]  6个字节
System.out.println("gbk编码:" + Arrays.toString(gbk));//[-42, -48, -71, -6] 4个字节
// 解码
String code1 = new String(utf, "utf-8"); // 中国
String code2 = new String(utf, "gbk"); // gbk解码:涓浗  gbk用2个字节解码,所以会多一个字符
String code3 = new String(gbk, "utf-8"); // gbk用utf-8解码:?й? utf-8解码需要6个字节
System.out.println("--------------------");
System.out.println("utf-8解码:" + code1);
System.out.println("gbk解码:" + code2);
System.out.println("gbk用utf-8解码:" + code3);
System.out.println("---------------------");
System.out.println("用utf-8编码回去");
code3 = new String(code3.getBytes("utf-8"), "gbk"); // 锟叫癸拷   gbk用utf-8解码后无法编回去
System.out.println(code3);




在JSP页面获取表单的值时会出现乱码,有两种解决方法:
1.在调用getParameter之前通过request.setCharacterEncoding设置字符编码

2.调用new String(str.getBytes("iso8859-1"), "UTF-8");编码后解码


注意:
虽然说utf是为了使用更少的空间而使用的,但那只是相对于unicode编码来说,如果已经知道是汉字,则使用GB2312/GBK无疑是最节省的。不过另一方面,值得说明的是,虽然utf编码对汉字使用3个字节,但即使对于汉字网页,utf编码也会比unicode编码节省,因为网页中包含了很多的英文字符。
分享到:
评论

相关推荐

    汉字编码问题总结

    汉字编码问题总结 GB2312-80 编码是中华人民共和国国家汉字信息交换用编码,全称《信息交换用汉字编码字符集--基本集》,由国家标准总局发布,1981年5月1日实施,通行于大陆。新加坡等地也使用此编码。GB2312 收录...

    常用编码方式中英文对照表

    下面是常用编码方式的中英文对照表: 一、ASCII 编码 * 中文名称:ASCII 编码 * 英文名称:ASCII Code * 编码范围:0x00-0x7F * 特点:使用 7 位二进制数表示一个字符,总共可以表示 128 个字符。 * 应用场景:...

    常用汉字的unicode编码

    ### 常用汉字的Unicode编码 #### 一、引言 在计算机科学与信息技术领域,字符编码是一项至关重要的技术,它确保了不同系统间文本数据的正确传输和显示。Unicode作为国际上广泛采用的一种字符编码标准,为每种语言...

    数字逻辑电路 《常用编码器》习题及参考答案.doc

    《常用编码器》是数字逻辑电路中的一个重要主题,主要涉及如何将多个输入信号转换成一个或多个二进制代码的过程。编码器的主要功能是将多个输入线中的一个或多个有效状态编码为一个特定的二进制输出。在这个文档中,...

    wireshark常用用法总结

    ### Wireshark常用用法总结 #### 一、Wireshark简介 Wireshark是一款强大的网络包分析工具,被广泛应用于网络安全分析、故障排查、性能优化等领域。它能够捕获并解析网络通信中的数据包,提供详细的协议分析及丰富...

    java编码总结1

    【标题】:“Java编码总结1”揭示了关于Java编程中的编码规范、常见问题以及最佳实践。这个主题旨在帮助开发者理解如何在Java项目中正确处理字符编码,以避免常见的乱码问题,提高代码质量和可读性。 【描述】:这...

    常用的几种编码格式

    根据提供的文件信息,可以看出这些内容涉及到了不同的编辑器、数据查询工具及操作,但与“常用的几种编码格式”这一主题关系不大。为了更好地满足需求,本文将围绕“常用的几种编码格式”这一主题展开讨论。 ### ...

    常用红外遥控编码资料集

    ### 常用红外遥控编码资料集 #### 红外遥控编码基础知识 红外遥控技术是一种广泛应用于家用电器、汽车、安全系统等领域的无线通信技术。它通过发射特定的红外信号来实现对设备的控制。在红外遥控系统中,编码方式...

    编码电子锁设计总结报告

    74LS20和74LS00是常用的数字逻辑门集成电路。74LS20是四输入与非门,74LS00是双输入与非门,它们都遵循有0出1,无0出0的逻辑规则。这些芯片可以组合成各种逻辑电路,例如清零和复位电路。NE555定时器则是一个多功能...

    HTML编码方法总结,常用

    自己总结的小经验,很基础,将一些专业素养的,英文解释也放进去了。可以参考。平时忘了什么就瞅瞅,大佬们可以查阅一下。平时下载可以用来复习或者挑选。

    常用字符集编码详解

    总结而言,字符集编码的选择和使用直接影响到数据的存储、传输和展示效果。随着全球化的发展,Unicode及其变种如UTF-8已成为国际间数据交换的首选编码,它不仅解决了多语言字符的兼容性问题,也为未来新字符的加入...

    BIG5编码表

    从A440至A8F0区间,BIG5编码表列出了大量常用汉字,包括一、乙、丁、七、乃、九、了、二、人、儿、入、八、几、刀、刁、力、匕、十、卜、又、三、下、丈、上、丫、丸、凡、久、么、也、乞、于等。这些汉字是构成繁体...

    常用的小波变换程序:小波编码实现

    总结来说,小波编码是利用小波变换进行数据压缩的一种方法,其核心在于将数据在小波域进行分析和编码,适用于需要高效压缩和准确恢复信号的场景。"常用的小波变换程序"提供的源代码资源,可以帮助开发者深入了解小波...

    Python编码规范(Google)

    ### 总结 通过遵循Google提供的Python编码规范,开发者能够编写出更加一致、易于理解和维护的代码。上述关键知识点涵盖了基本的代码风格和格式化规则,通过实践这些建议,可以帮助提升个人或团队项目的整体质量。...

    javascript 常用方法总结

    JavaScript 常用方法总结 JavaScript 是一种广泛应用于 Web 开发的编程语言,提供了许多实用的方法来操作字符串和数组。下面将对 JavaScript 中常用的字符串和数组方法进行总结。 字符串方法 1. `charAt()`: 返回...

    C#获取网页编码—总结.pdf

    - UTF-8编码灵活,节省空间,是目前互联网上最常用的字符编码。 在C#中,获取网页编码通常涉及到HTTP请求和响应的处理。使用`HttpWebRequest`或`HttpClient`类发送请求,然后从响应头中提取`Content-Type`字段,...

    常用字符集编码原理及解决方法

    总结来说,字符集编码的原理主要包括字符的数字化表示、编码范围、编码格式以及它们之间的兼容性。掌握这些知识能帮助我们更好地处理文本数据,避免乱码问题,实现跨平台的文本通信。在实际应用中,我们需要根据具体...

    Java中编码方式和Unicode知识总结

    以下是对Java中编码方式和Unicode的知识点总结: 1. 基本概念 - bit:计算机存储的最小单位,只能是0或者1。 - byte:一个字节是8个bit,计算机表示的基本单位。 - 字节换算:1KB(千字节)= 1024字节,1MB(兆字节...

Global site tag (gtag.js) - Google Analytics