程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> PHP utf-8和gb2312編碼轉換亂碼的問題

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

編輯:關於PHP編程

經過一時間的 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 小。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved