php UTF8 檔案的簽名問題

來源:互聯網
上載者:User

也就是 有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簽名,不然再次開啟檔案時,還是系統的預設編碼而已。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.