php UTF8 文件的签名问题


Posted in PHP onOctober 30, 2009

也就是 有BOM 格式编码,或者 无BOM格式编码。
如果看文件的内容,是看不出任何差别的,以下列文件(schema.sqlite.sql)内容为例:
schema.sqlite.sql

CREATE TABLE guestbook ( 
id INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT, 
email VARCHAR(32) NOT NULL DEFAULT 'noemail@test.com', 
comment TEXT NULL, 
created DATETIME NOT NULL 
); 
CREATE INDEX "id" ON "guestbook" ("id");

如果不带签名,则文件的大小为232字节,如果带签名,则文件大小为235字节。
UTF8签名有3个字节(内容为:EFBBBF),是专门用来告诉软件:该文件是UTF8编码的。
在一般情况下,有无签名不会带来问题,因为编辑器或者其他软件可以按照文本的内容来推断出是否是UTF8。
但有些时候还是会导致问题,比如上诉文件。该文件是sql语句文件,程序恰好要通过以下语句(php)来执行该sql:
$schemaSql = file_get_contents(dirname(__FILE__) . '/schema.sqlite.sql'); 
$dbAdapter->getConnection()->exec($schemaSql);

在这种情况下,带有签名的文件就会导致问题了,因为“UTF8签名用的三个字节”其实是位于文件的最前面。所以导致了上面的语句无法成功运行。
解决的办法也很简单,去掉该文件UTF8签名即可。
当然,上面文件的内容其实都是单字节的,是没有必要保存为UTF8编码的。

补充:全部是单字节内容的文件除非加了UTF8签名,不然再次打开文件时,还是系统的默认编码而已。

PHP 相关文章推荐
图书管理程序(三)
Oct 09 PHP
PHP读MYSQL中文乱码的解决方法
Dec 17 PHP
PHP远程连接MYSQL数据库非常慢的解决方法
Jul 05 PHP
php-accelerator网站加速PHP缓冲的方法
Jul 30 PHP
五款常用mysql slow log分析工具的比较分析
May 22 PHP
PHP mcrypt可逆加密算法分析
Jul 19 PHP
php中实现简单的ACL 完结篇
Sep 07 PHP
php获取客户端电脑屏幕参数的方法
Jan 09 PHP
Zend Framework实现留言本分页功能(附demo源码下载)
Mar 22 PHP
Yii2.0表关联查询实例分析
Jul 18 PHP
解决laravel资源加载路径设置的问题
Oct 14 PHP
PHP框架实现WebSocket在线聊天通讯系统
Nov 21 PHP
PHP+MySQL 手工注入语句大全 推荐
Oct 30 #PHP
php 攻击方法之谈php+mysql注射语句构造
Oct 30 #PHP
PHP 文件上传源码分析(RFC1867)
Oct 30 #PHP
浅谈PHP 闭包特性在实际应用中的问题
Oct 30 #PHP
php实现jQuery扩展函数
Oct 30 #PHP
PHP 读取和修改大文件的某行内容的代码
Oct 30 #PHP
PHP 批量删除数据的方法分析
Oct 30 #PHP
You might like
克隆一个新项目的快捷方式
2013/04/10 PHP
file_get_contents("php://input", "r")实例介绍
2013/07/01 PHP
微信公众平台天气预报功能开发
2014/07/06 PHP
PHP处理JSON字符串key缺少双引号的解决方法
2014/09/16 PHP
php采集中国代理服务器网的方法
2015/06/16 PHP
PHP编程实现多维数组按照某个键值排序的方法小结【2种方法】
2017/04/27 PHP
js网页版计算器的简单实现
2013/07/02 Javascript
jQuery中after的两种用法实例
2013/07/03 Javascript
图片上传判断及预览脚本的效果实例
2013/08/07 Javascript
Nodejs+express+html5 实现拖拽上传
2014/08/08 NodeJs
jQuery实现网站添加高亮突出显示效果的方法
2015/06/26 Javascript
JavaScript中Null与Undefined的区别解析
2015/06/30 Javascript
以Python代码实例展示kNN算法的实际运用
2015/10/26 Javascript
js简单倒计时实现代码
2016/04/30 Javascript
如何利用JSHint减少JavaScript的错误
2016/08/23 Javascript
js 数据存储和DOM编程
2017/02/09 Javascript
JavaScript中的toString()和toLocaleString()方法的区别
2017/02/15 Javascript
vue按需加载组件webpack require.ensure的方法
2017/12/13 Javascript
Vue使用枚举类型实现HTML下拉框步骤详解
2018/02/05 Javascript
Vue基础学习之项目整合及优化
2019/06/02 Javascript
[00:35]DOTA2上海特级锦标赛 Newbee战队宣传片
2016/03/03 DOTA
python使用PyGame模块播放声音的方法
2015/05/20 Python
Python对象属性自动更新操作示例
2018/06/15 Python
Python3.5文件修改操作实例分析
2019/05/01 Python
Python使用Beautiful Soup爬取豆瓣音乐排行榜过程解析
2019/08/15 Python
Python脚本调试工具安装过程
2021/01/11 Python
CSS3等相关属性制作分页导航实现代码
2012/12/24 HTML / CSS
Trip.com香港网站:Ctrip携程旗下,全球最大的网上旅游社之一
2016/08/01 全球购物
J2SDK1.5与J2SDK5.0有什么区别
2012/09/19 面试题
施惠特软件测试面试题以及笔试题
2015/05/13 面试题
淘宝网店营销策划书
2014/01/11 职场文书
乡镇遵守党的政治纪律情况对照检查材料
2014/09/26 职场文书
人事主管岗位职责
2015/02/04 职场文书
vue 实现弹窗关闭后刷新效果
2022/04/08 Vue.js
Win11安装升级时提示“该电脑必须支持安全启动”
2022/04/19 数码科技
MySQL中JOIN连接的基本用法实例
2022/06/05 MySQL