UTF-8-SIG和UTF-8 with BOM有什么区别


用 Sublime Text 打开一个文件,出现一个框框,提示要点选UTF-8-SIG(100%) 或 UTF-8 with BOM。BOM —— Byte Order Mark,中文名译作“字节顺序标记”。

前言

找到一段关于 BOM 的说明:

在UCS 编码中有一个叫做 "Zero Width No-Break Space" ,中文译名作“零宽无间断间隔”的字符,它的编码是 FEFF。而 FFFE 在 UCS 中是不存在的字符,所以不应该出现在实际传输中。UCS 规范建议我们在传输字节流前,先传输字符 "Zero Width No-Break Space"。这样如果接收者收到 FEFF,就表明这个字节流是 Big-Endian 的;如果收到FFFE,就表明这个字节流是 Little- Endian 的。因此字符 "Zero Width No-Break Space" (“零宽无间断间隔”)又被称作 BOM。


UTF-8 不需要 BOM 来表明字节顺序,但可以用 BOM 来表明编码方式。字符 "Zero Width No-Break Space" 的 UTF-8 编码是 EF BB BF。所以如果接收者收到以 EF BB BF 开头的字节流,就知道这是 UTF-8编码了。Windows 就是使用 BOM 来标记文本文件的编码方式的。


字符U+FEFF如果出现在字节流的开头,则用来标识该字节流的字节序,是高位在前还是低位在前。如果它出现在字节流的中间,则表达零宽度非换行空格的意义,用户看起来就是一个空格。从Unicode3.2开始,U+FEFF只能出现在字节流的开头,只能用于标识字节序,就如它的名称——字节序标记——所表示的一样;除此以外的用法已被舍弃。取而代之的是,使用U+2060来表达零宽度无断空白。


类似WINDOWS自带的记事本等软件,在保存一个以UTF-8编码的文件时,会在文件开始的地方插入三个不可见的字符(0xEF 0xBB 0xBF,即BOM)。它是一串隐藏的字符,用于让记事本等编辑器识别这个文件是否以UTF-8编码。对于一般的文件,这样并不会产生什么麻烦。但对于 PHP来说,BOM是个大麻烦。


PHP并不会忽略BOM,所以在读取、包含或者引用这些文件时,会把BOM作为该文件开头正文的一部分。根据嵌入式语言的特点,这串字符将被直接执行(显示)出来。由此造成即使页面的 top padding 设置为0,也无法让整个网页紧贴浏览器顶部,因为在html一开头有这3个字符呢!

详解

BOM (Byte Order Mark) 存在:UTF-8 with BOM 包含一个特殊的字节顺序标记 (BOM),它是一个非打印字符,通常用于表示文本文件的字节顺序(大端或小端)。这个BOM会在文件开头插入几个字节,用于指示文件的编码方式。而 “UTF-8-SIG” 是在UTF-8编码下,为了避免BOM的问题,特意在文件开头添加了一个特殊的标记,通常是0xFEFF。这个标记会告诉文本处理程序文件采用UTF-8编码兼容性:某些文本编辑器和应用程序可以识别BOM并根据其存在来正确解释文本文件的编码,但也有一些应用程序可能不支持BOM,可能会将它们解释为文本内容的一部分。相比之下,“UTF-8-SIG” 标记通常更可靠,因为它不会引起与BOM相关的问题

结论

在选择使用哪种编码时,通常建议使用 “UTF-8-SIG”,因为它更可靠,特别是在涉及多个不同应用程序或平台的文本文件时。如果没有特殊要求,“UTF-8-SIG” 是一个较好的选择,因为它不会引入额外的BOM字符,但仍然能够表示UTF-8编码。

以上就是UTF-8-SIG 和 UTF-8 with BOM 有什么区别,该怎么选的详细内容,更多相关资料请阅读主机测评网其它文章!

十个 Web 日志安全性分析工具

我经常听到朋友问,是否有更好的Web日志安全性分析工具?首先,我们应该清楚的是,日志文件不仅可以帮助我们追踪入侵者的来源并找到其攻击路径,而且在正常的操作和维护中,日志还可以反映出许多安全攻击。一个简单易用的Web日志分析工具可以大大提高效率。当前,行业中有许...
服务器安全Web日志分析工具

安卓应用乾坤大挪移,Ubuntu上的搬运工:ARChon

Google最近发布了首批能在Chrome OS本地运行的安卓应用集,通过‘安卓运行时’扩展完成了该壮举。现在,一位开发者已经指明了将安卓应用带入桌面版Chrome的路。弗拉德·菲利波夫的chromeos-apk脚本和ARChon安卓运行时扩展手拉手一起开展工...
ubuntu安卓应用ARChon

在服务器应用虚拟化中发现价值

一些IT专业人员可以看到从服务器操作系统抽象应用程序的潜力。现在,这项技术刚刚起步。在服务器虚拟化市场中出现了可以轻松应用程序安装和移动性的可能性,从服务器操作系统抽象应用程序的产品。但是现在,“潜力”是一个操作词汇。这种抽象也被称为服务器应用程序虚拟化。这是...
服务器虚拟主机虚拟化

网站服务器被CC攻击防御策略

作为站长或者公司的网站的网管,什么最可怕?显然是网站受到的DDoS攻击。大家都有这样的经历,就是在访问某一公司网站或者论坛时,如果这个网站或者论坛流量比较大,访问的人比较多,打开页面的速度会比较慢,对不?!一般来说,访问的人越多,网站或论坛的页面越多,数据库就...
服务器安全CC攻击网站服务器