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