經過一時間的 php + mssql,感覺 mssql 對編碼的支持不是很好(其實還是自己沒有把握好啦),但是又還沒有來得急換數據庫,只能將就點,今天又在提交數據時出現了錯誤。
經過一時間的 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 小。