做网站用UTF-8还是GB2312?

news/2024/5/20 11:10:01/文章来源:https://blog.csdn.net/weixin_30691871/article/details/96753468

转载自 http://justjavac.javaeye.com/blog/695252

经常我们打开外国网站的时候出现乱码,又或者打开很多非英语的外国网站的时候,显示的都是口口口口口的字符,

  WordPress程序是用的UTF-8,很多cms用的是GB2312

  为什么有这么多编码?

  ● UTF-8GB2312有什么区别?

  我们在国内做网站是用UTF-8编码格式还是GB2312编码格式好? 

  一. 各种编码的来历

  可能很多同学一直对字符的各种编码方式懵懵懂懂,根本搞不清为什么他们有这么多编码。

  ANSI编码

  其实在很久很久以前,有一群人,他们决定用8个可以开合的晶体管来组合成不同的状态,以表示世界上的万物。他们看到8个开关状态是好的,于是他们把这称为"字节"

  开始计算机只在美国用。八位的字节一共可以组合出25628次方)种不同的状态。 

  他们把其中的编号从0开始的32种状态分别规定了特殊的用途,一但终端、打印机遇上约定好的这些字节被传过来时,就要做一些约定的动作。

  遇上00×10,终端就换行,遇上0×07, 终端就向人们嘟嘟叫,例好遇上0×1b, 打印机就打印反白的字,或者终端就用彩色显示字母。他们看到这样很好,于是就把这些0×20以下的字节状态称为"控制码"

  他们又把所有的空格、标点符号、数字、大小写字母分别用连续的字节状态表示,一直编到了第127号,这样计算机就可以用不同字节来存储英语的文字了。大家看到这样,都感觉很好,于是大家都把这个方案叫做 ANSI "Ascii"编码(American Standard Code for Information Interchange,美国信息互换标准代码)。当时世界上所有的计算机都用同样的ASCII方案来保存英文文字。

  扩展ANSI编码

  后来,就像建造巴比伦塔一样,世界各地的都开始使用计算机,但是很多国家用的不是英文,他们的字母里有许多是ASCII里没有的,为了可以在计算机保存他们的文字,他们决定采用127号之后的空位来表示这些新的字母、符号,还加入了很多画表格时需要用下到的横线、竖线、交叉等形状,一直把序号编到了最后一个状态255。从128255这一页的字符集被称"扩展字符集"。从此之后,贪婪的人类再没有新的状态可以用了,美国当时估计也没想到还有别的国家要用计算机的。

  GB2312编码

  当天朝人们得到计算机时,已经没有可以利用的字节状态来表示汉字,况且有6000多个常用汉字需要保存呢。天朝人民就不客气地把那些127号之后的奇异符号们直接取消掉。

  规定:一个小于127的字符的意义与原来相同,但两个大于127的字符连在一起时,就表示一个汉字,前面的一个字节(他称之为高字节)从0xA1用到0xF7,后面一个字节(低字节)从0xA10xFE,这样我们就可以组合出大约7000多个简体汉字了。

  在这些编码里,我们还把数学符号、罗马希腊的字母、日文的假名们都编进去了,连在 ASCII 里本来就有的数字、标点、字母都统统重新编了两个字节长的编码,这就是常说的"全角"字符,而原来在127号以下的那些就叫"半角"字符了。于是就把这种汉字方案叫做 "GB2312"GB2312 是对 ASCII 的中文扩展。

  GBK GB18030编码

  但是天朝的汉字太多了,我们很快就就发现有许多人的人名没有办法在这里打出来,特别是某些天朝领导的名字要是打不出很麻烦的。于是我们不得不继续把 GB2312 没有用到的码位找出来老实不客气地用上。

  后来还是不够用,于是干脆不再要求低字节一定是127号之后的内码,只要第一个字节是大于127就固定表示这是一个汉字的开始,不管后面跟的是不是扩展字符集里的内容。结果扩展之后的编码方案被称为 GBK 标准,GBK 包括了 GB2312 的所有内容,同时又增加了近20000个新的汉字(包括繁体字)和符号。

  后来少数民族也要用电脑了,于是我们再扩展,又加了几千个新的少数民族的字,GBK 扩成了 GB18030。从此之后,天朝民族的文化就可以在计算机时代中传承了。

  在这个标准里,最大的特点是两字节长的汉字字符和一字节长的英文字符并存于同一套编码方案里,因此他们写的程序为了支持中文处理,必须要注意字串里的每一个字节的值,如果这个值是大于127的,那么就认为一个双字节字符集里的字符出现了。

  那时候凡是受过编程学习的程序员都要每天念下面这个咒语数百遍的折磨:

  "一个汉字算两个英文字符!一个汉字算两个英文字符……"

  UNICODE编码

  因为当时各个国家都像天朝这样搞出一套自己的编码标准,结果互相之间谁也不懂谁的编码,谁也不支持别人的编码,连大陆和台湾这样只相隔了150海里,使用着同一种语言的兄弟地区,也分别采用了不同的编码方案:

  当时的天朝人想让电脑显示汉字,就必须装上一个"汉字系统"。专门用来处理汉字的显示、输入的问题。

  但是那个装台湾的人士写的程序就必须加装另一套支持 BIG5 编码的"倚天汉字系统"才可以用,装错了字符系统,显示就会乱了套!这怎么办?而且世界民族中还有那些暂时用不上电脑的穷苦人民,他们的文字又怎么办?

  正在这时,天使及时出现了——一个叫 ISO (国际标谁化组织)的国际组织决定着手解决这个问题。他们采用的方法很简单:废了所有的地区性编码方案,重新搞一个包括了地球上所有文化、所有字母和符号的编码!他们打算叫它 UCS, 俗称 UNICODE 。( Universal Multiple-Octet Coded Character Set

  在UNICODE 中,一个汉字算两个英文字符的时代已经快过去了。

  无论是半角的英文字母,还是全角的汉字,它们都是统一的"一个字符"!同时,也都是统一的"两个字节""

  UTF-8UTF-16

  UNICODE 来到时,一起到来的还有计算机网络的兴起,UNICODE 如何在网络上传输也是一个必须考虑的问题,于是面向传输的众多 UTFUCS Transfer Format)标准出现了,顾名思义,UTF8就是每次8个位传输数据,而UTF16就是每次16个位,只不过为了传输时的可靠性,从UNICODEUTF时并不是直接的对应,而是要过一些算法和规则来转换。

  未来的UCS-4

  如前所述,UNICODE 是用两个字节来表示为一个字符,他总共可以组合出65535不同的字符,这大概已经可以覆盖世界上所有文化的符号。如果还不够也没有关系,ISO已经准备了UCS-4方案,说简单了就是四个字节来表示一个字符,这样我们就可以组合出21亿个不同的字符出来(最高位有其他用途),这大概可以用到天朝成立银河联邦成立那一天吧!

  二. 为什么有些网站打开有时候会是乱码

  网页乱码是浏览器(如IE等)对HTML网页解释时形成的。

  如果在浏览网站网页的代码写错语系(比较少见),有形如:

<HTML>

<HEAD>

<META CONTENT="text/htmlcharset=ISO-8859-1"></HEAD>……

</HTML>

  的语句,浏览器在显示此页时,就会出现乱码。因为浏览器会将此页语种辨认为"欧洲语系"

  解决的办法是将语种"ISO-8859-1"改为GB2312,如果是繁体网页则改为BIG5

  还有一种可能比较大,就是网页并没有标明他用的是何种语系,即没有

  <META CONTENT="text/htmlcharset=XXXXX">,这一行。

  而你的计算机默认也不是这种语系,比方我们访问某些日文网站,经常出现这个问题。这个主要是由于程序员是面向当地的人开发的网站,由于当地都是默认语系,所以没有乱码种情况,而你是外来人,你的操作系统本身默认不是当地的语系。所以要手动改语系。

  至于出现口口口口口口这种情况

  这是由于网站并没有采用UTF-8编码而是采用的当地的编码,如蒙古语的,阿拉伯语的编码,你的计算机中并没有这种编码,所以不能识别。

  解决办法是,事先为浏览器安装多语言支持包(例如在安装IE时要安装多语言支持包),这样在浏览网页出现乱码时,就可以在浏览器中选择菜单栏下的"查看"/"编码"/"自动选择"/蒙古),如为繁体中文则选择"查看"/"编码"/"自动选择"/阿拉伯语,其它语言依此类推选择相应的语系,这样可消除网页乱码现象。

  三. 目前开发网站用什么编码比较好

  我们一般通俗的理解为:

  UTF-8是世界性通用代码,也完美的支持中文编码,如果我们做的网站能让国外用户正常的访问,就最好用UTF-8

  GB2312属于中文编码,主要针对国内用户使用,如果国外用户访问GB2312编码的网站就会变乱码。

  网友的反馈一般觉得是用UTF-8GB2312要多很多,大家都比较赞同用UTF-8

  从一张外国网站的调查也可看得出:

201102091332125107.jpg

由此图可以看出,2001-2008年期间,GB2312编码的使用情况虽然幅度不大,但还是在稳定上升的;蓝色的线表示出用UTF-8的网站越来越多了。

  我挑选了国内部分几个大的门户网站,看看他们用的是哪种编码格式:

201102091332139992.jpg

也许有同学就会问了为什么国内几个网站用GB2312反而更多些呢。

  我也对这个疑问进行了思考,我觉得。应该有3种原因:

  1. 国内这些网站本身历史也比较长,开始使用的就是 GB2312编码,现在改成 UTF-8(以前的网页)转换的难度和风险太大。

  2. UTF-8编码的文件比GB2312更占空间一些,虽然目前的硬件环境下可以忽略,但是这些门户网站为了减少服务器负载基本上所有的页面都生成了静态页,UTF-8保存起来文件会比较大,对于门户级别的网站每天生成的文件量还是非常巨大,带来的存储成本相应提高。

  3. 由于UTF-8的编码比GB2312解码的网络传输数据量要大,对于门户级别的网站来说。这个无形之间就要增大带宽,用GB2312对网络流量无疑是最好的优化。

  所以在新做站的情况下,建议还是选择UTF-8比较好。因为没有上面那些原因,兼容为上策。

转载于:https://www.cnblogs.com/striveford/articles/1950155.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.luyixian.cn/news_show_796551.aspx

如若内容造成侵权/违法违规/事实不符,请联系dt猫网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

小型电子商务网站设计原则

最近谈得最多的话题莫过于大规模&#xff0c;大数据量&#xff0c;高性能&#xff0c;高并发等架构话题&#xff0c;其实一个电子商务网站开始时一定是小规模&#xff0c;小数据量&#xff0c;用不着把架构弄得过于复杂。高度设计、过度扩展(高德纳大爷也说过&#xff0c;"…

Mysql在大型网站的应用架构演变

写在最前: 本文主要描述在网站的不同的并发访问量级下&#xff0c;Mysql架构的演变 可扩展性 架构的可扩展性往往和并发是息息相关&#xff0c;没有并发的增长&#xff0c;也就没有必要做高可扩展性的架构&#xff0c;这里对可扩展性进行简单介绍一下&#xff0c;常用的扩展手段…

(转载)可扩展、高可用、负载均衡网站架构设计方案

可扩展、高可用、负载均衡网站架构设计方案作者&#xff1a;田逸(sery163.com) 本作品已刊登在《IT实验室周报》第6期第6版 基本需求: 1、 高可用性&#xff1a;将停止服务时间降低到最低甚至是不间断服务 2、 可扩展性&#xff1a;随着访问的增加&#xff0c;系统具备良好的…

MOUSEOVER在拼接的HTML无效处理

正常情况下&#xff1a; //鼠标移入移出&#xff08;顶部企业图标信息&#xff09;$(".patternBg").mouseover(function (){ $(".enterpriseContent").show(); }).mouseout(function () {$(".enterpriseContent").hide();}); 修改成&#x…

SQl语句查存储过程\触发器\约束(网站数据库转移缺漏审查)

网站开发最让我们头疼的就是数据的架构.本地开发很轻松.程序只需要打包dll就可以了,但是数据库要架设到空间服务器上,就要转移.一不小心就会忘了一些存储过程,触发器,约束.这里为大家提供几个查用的检查.能够快速找出有哪些东西是忘记传了.很实用.有好的方法,请知道. 该条语句查…

从小型网站到超大规模网站的MySQL参考架构

Oracle发布《面向大规模可伸缩网站基础设施的MySQL参考架构》白皮书&#xff0c;针对将MySQL用作数据存储的不同类型和不同规模的网站给出了推荐的拓扑结构。 根据分别提供4类服务——用户和会话管理、电子商务、分析类应用 (多结构数据)和CMS&#xff08;元数据&#xff09;—…

在不同尺寸屏幕下浏览网站效果 - Responsivator

如果你需要开发响应式的网站的话&#xff0c;使用一个必要的浏览工具来检验不同尺寸屏幕下显示效果还是非常有用的&#xff0c;在今天的这篇文章中&#xff0c;我们再给大家介绍另外一个不错的在线工具 - Responsivator&#xff0c;它提供了很多不同的尺寸屏幕的展示效果&#…

行业网站设计心得

作者&#xff1a;何迁 时间&#xff1a; 2004-08-18 文档类型&#xff1a;原创 来自&#xff1a;蓝色理想 浏览统计 total:11158 | year:596 | Quarter:596 | Month:596 | Week:47 | today:7 很多设计师认为做好了企业网站就一定能够做好行业网站的设计&#xff0c;其实对设…

云计算之路-阿里云上:网站故障致歉

后续进展&#xff1a;云计算之路-阿里云上&#xff1a;向大家汇报一下今天上午的网站故障 今天上午&#xff08;5月16日&#xff09;9:30~9:40左右&#xff0c;下午16:30~17:00左右&#xff0c;由于博客站点的Web服务器CPU大幅波动&#xff08;有如坐过山车&#xff09;&#x…

带给你灵感的20个漂亮的单页网站设计作品

带给你灵感的20个漂亮的单页网站设计作品 单页网站是指只有一个页面的网站&#xff0c;这种形式的网站曾经非常流行&#xff0c;现在依然有很多人喜欢。不过&#xff0c;并不是每个网站都适合做成单页&#xff0c;一般都是内容比较少而且将来内容也不怎么增加的情况才适合这样做…

寻找网页设计灵感的27个最佳网站推荐

今天&#xff0c;本文要向大家推荐的是27个寻找网页设计灵感的最佳网站。设计师们可通过这些网站收集的优秀网页设计作品来获取灵感&#xff0c;进而设计出更加时尚、更有创意的作品。如果你有收藏这个列表中遗漏的网站&#xff0c;欢迎在评论中与大家分享。 CSS Nature Desig…

优秀网页设计:20佳别出心裁的国外单页网站作品

单页网站是非常好的灵感来源&#xff0c;这些网站界面简洁、主题突出、设计精美&#xff0c;有创意的动态效果&#xff0c;带给访客强烈的视觉冲击。这种形式的网站需要把内容都放在一个页面中&#xff0c;只有重要内容才会展现在屏幕中。下面收集了20佳优秀的单页网站作品&…

2068个开源的网站模板

在网上溜达的时候发了这个好网站——opendesigns.org&#xff0c;上面分享了2068个免费的网站模板。提供了搜索功能&#xff0c;可以根据风格和功能&#xff08;艺术、教育、画廊、杂志、作品集、电子商务等&#xff09;、颜色以及关键字搜索模板&#xff0c;高级搜索模式还支持…

『优秀作品』20个激发灵感的橙色风格网站设计

『优秀作品』20个激发灵感的橙色风格网站设计 橙色是一种欢快活泼的色彩&#xff0c;是暖色系中最温暖的色&#xff0c;它使人联想到金色的秋天&#xff0c;丰硕的果实&#xff0c;是一种富足、快乐而幸福的颜色。今天&#xff0c;本文收集了20个橙色风格的网页设计作品与大家分…

网站项目必备——12款经典的白富美型 jQuery 图片轮播插件

图片轮播是网站中的常用功能&#xff0c;用于在有限的网页空间内展示一组产品图片或者照片&#xff0c;同时还有非常吸引人的动画效果。本文向大家推荐12款实用的 jQuery 图片轮播效果插件&#xff0c;帮助你在你的项目中加入一些效果精美的图片轮播效果&#xff0c;希望这些插…

分享50个优秀的电子商务网站设计案例

对于电子商务网站来说&#xff0c;也许销售更多产品比漂亮的外观设计更重要&#xff0c;不过漂亮的东西总是能给用户留下深刻的印象。今天&#xff0c;这篇文章与大家分享50个优秀的电子商务网站设计作品案例&#xff0c;希望能带给你灵感。 Free People Me & Mommy-to-be…

冒牌网站提供假冒卡巴斯基KIS7.0下载

近日&#xff0c;多位用户反映在多家网络论坛提供假冒的卡巴斯基互联网安全套装7.0简体中文版下载。 当用户按提供的地址下载后&#xff0c;将会下载回一个文件压缩包&#xff0c;解压后可以找到一个名为Kaspersky7.0的可执行文件&#xff0c;文件大小为25.4MB。但是执行该文件…

《时代周刊》评选出07年50个最佳网站 2007-07-10

来源 : cnbeta 时间:2007-07-10 美国《时代周刊》近日公布2007年50个最佳网站&#xff0c;由陈士骏与Chad Hurley创办的YouTube与近期窜红的同类型网站Twitter上榜。 《时代周刊》还列出了网站评级和投票数等信息。2007年这50个最佳网站分为艺术与休闲(Arts & Leisure…

(转)理清网站数据分析思路导图

下图是一个网站分析的生命周期示意图&#xff0c;在确认好分析需求并收集好我们所需要的数据后&#xff08;强调一下&#xff0c;明确分析需求很重要&#xff0c;这可以避免为了分析而分析&#xff09;&#xff0c;我们就可以充分使用网站分析工具的各种报告对数据展开分析。 但…

一个简单企业信息网站架构

前段时间做了一个简单的企业信息网站&#xff0c;主要用到一些开源的框架和插件&#xff0c;网站开发完了&#xff0c;把用到的东西写出来分享一下 网站功能分析 &#xff08;1&#xff09;网站信息维护&#xff1a;网站信息分为很多种类型&#xff0c;有自己网站发布的新闻、知…