您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關解決php ajax傳值亂碼問題的方法,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
php ajax傳值亂碼的解決辦法:1、將前后臺頁面以及數據庫統一采用UTF8編碼;2、在存入數據庫時使用“mysql_query("set names gb2312");”方法;3、使用ICONV函數對從數據庫中取出的字符串進行編碼轉換。
在php網站開發中,為了增加用戶體驗度,Ajax是一種經常使用的技術,但是對于初學者來說,時常會碰到Ajax傳值中文字符串時變成亂碼的問題,有什么辦法可以解決PHP AJAX傳值中文字符亂碼的問題呢?
我們知道Ajax技術由JavaScript演變而來,而javascript使用UTF-8編碼,當前后臺頁面采用GBK或者其他編碼,同時沒有進行編碼轉換時,就會出現中文字符亂碼問題。
PHP Ajax傳值中文字符亂碼解決方法
方法一、前后臺頁面以及數據庫統一采用UTF8編碼,這是最簡單的方法。
方法二、當網站已采用了諸如GBK/GB2312編碼時,分兩種情況:
1、Ajax發送中文字符、PHP(后臺程序)進行接收發生亂碼時,使用GBK與UTF8的轉換函數對接受的字符串進行編碼轉換,再存入相關數據庫,這里假設數據庫采用的編碼是GBK或者GB2312,如果配置的PHP運行環境支持ICONV函數,你也可使用ICONV函數進行編碼轉換,然后在存入數據庫時
mysql_query("set names gb2312");
即可解決Ajax傳值中文亂碼問題。
2、PHP發送中文字符、Ajax(前臺頁面)進行接收發生亂碼時,同樣可以使用ICONV函數對從數據庫中取出的字符串進行編碼轉換,再傳值至Ajax前臺,即responseText。或者在PHP(后臺程序)輸出字符流之前加上
header('Content-type: text/html;charset=gb2312');
即可。特別指出:在使用Ajax做多級聯動(比如省份城市聯動)時,采用xml交互形式,在輸出XML之前也必須加上header。
同時貼出GB2312與UTF8的轉換函數,方便大家在遇到Ajax中文亂碼問題時多一種解決方法。
function gb2utf8($gb,$filename) { if(!trim($gb)) return $gb; //$filename="gb2312.txt"; $tmp=file($filename); $codetable=array(); while(list($key,$value)=each($tmp)) $codetable[hexdec(substr($value,0,6))]=substr($value,7,6); $utf8=""; while($gb) { if (ord(substr($gb,0,1))>127) { $thisgb=substr($gb,0,2); $gb=substr($gb,2,strlen($gb)); $utf8.=u2utf8(hexdec($codetable[hexdec(bin2hex($thisgb))-0x8080])); } else { $gb=substr($gb,1,strlen($gb)); $utf8.=u2utf8(substr($gb,0,1)); } } $ret=""; for($i=0;$i<strlen($utf8);$i+=3) $ret.=chr(substr($utf8,$i,3)); return $ret; } function u2utf8($c) { for($i=0;$i<count($c);$i++) $str=""; if ($c < 0x80) { $str.=$c; } else if ($c < 0x800) { $str.=(0xC0 $c>>6); $str.=(0x80 $c & 0x3F); } else if ($c < 0x10000) { $str.=(0xE0 $c>>12); $str.=(0x80 $c>>6 & 0x3F); $str.=(0x80 $c & 0x3F); } else if ($c < 0x200000) { $str.=(0xF0 $c>>18); $str.=(0x80 $c>>12 & 0x3F); $str.=(0x80 $c>>6 & 0x3F); $str.=(0x80 $c & 0x3F); } return $str; }
注:此函數需要使用GB2312中文編碼表,請點擊這里下載,由于是采用gb2312,對于一些比較生僻的詞在轉換時可能會出現亂碼。
關于解決php ajax傳值亂碼問題的方法就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。