PHP utf-8和gb2312編碼轉換亂碼的問題

來源:互聯網
上載者:User

經過一時間的 php + mssql,感覺 mssql 對編碼的支援不是很好(其實還是自己沒有把握好啦),但是又還沒有來得急換資料庫,只能將就點,今天又在提交資料時出現了錯誤。

由於提交的 ntext 欄位的內容比較多,大約有 220 KB,所以造成了我的誤解,以為是文章太長而引起的錯誤。我一看 php 配置,發現  php 對 mssql.textsize 的支援已經在 400 K了,怎麼還出錯?開啟錯誤後才發現,原來不是文章太長,而是編碼引起的錯誤。錯誤如下:

 代碼如下 複製代碼
Notice: iconv() [function.iconv]: Detected an illegal character in input string in...。

 英文實在太爛,只是知道 iconv() 函數出問題。google 翻譯,說是輸入字串中檢測到非法字元。恍然大悟。

根據錯誤提示到網上找到問題的解決辦法,就是在 iconv() 的第二個參數加個 //IGNORE ,就是忽略錯誤的意思。代碼如下:

 代碼如下 複製代碼
iconv("utf-8", "gbk//IGNORE", $str);

測試,提交成功。

註:網友經驗,gbk 的範圍比 gb2313 大,所以用 gbk 編碼的出錯率比 gb2313 小。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.