經(jīng)過一時間的 php + mssql,感覺 mssql 對編碼的支持不是很好(其實還是自己沒有把握好啦),但是又還沒有來得急換數(shù)據(jù)庫,只能將就點,今天又在提交數(shù)據(jù)時出現(xiàn)了錯誤。
由于提交的 ntext 字段的內(nèi)容比較多,大約有 220 KB,所以造成了我的誤解,以為是文章太長而引起的錯誤。我一看 php 配置,發(fā)現(xiàn) php 對 mssql.textsize 的支持已經(jīng)在 400 K了,怎么還出錯?開啟錯誤后才發(fā)現(xiàn),原來不是文章太長,而是編碼引起的錯誤。錯誤如下:
英文實在太爛,只是知道 iconv() 函數(shù)出問題。google 翻譯,說是輸入字符串中檢測到非法字符。恍然大悟。
根據(jù)錯誤提示到網(wǎng)上找到問題的解決辦法,就是在 iconv() 的第二個參數(shù)加個 //IGNORE,就是忽略錯誤的意思,代碼如下:
iconv("utf-8", "gbk//IGNORE", $str);
測試,提交成功。
注:網(wǎng)友經(jīng)驗,gbk 的范圍比 gb2313 大,所以用 gbk 編碼的出錯率比 gb2313 小。