也就是 有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簽名,不然再次開啟檔案時,還是系統的預設編碼而已。
http://www.bkjia.com/PHPjc/320710.htmlwww.bkjia.comtruehttp://www.bkjia.com/PHPjc/320710.htmlTechArticle也就是 有BOM 格式編碼,或者 無BOM格式編碼。 如果看檔案的內容,是看不出任何差別的,以下列檔案(schema.sqlite.sql)內容為例: schema.sq...