小編給大家分享一下php用get方法從url上獲取中文亂碼的解決辦法,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
創(chuàng)新互聯(lián)公司堅持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:做網(wǎng)站、成都網(wǎng)站制作、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時代的高州網(wǎng)站設(shè)計、移動媒體設(shè)計的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!php get參數(shù)亂碼的解決辦法:1、使用“iconv("gb2312","UTF-8",$gonghui);”方法解決亂碼問題;2、通過“mb_convert_encoding ”方法解決亂碼問題。
php用get方法從url上獲得的中文亂碼解決辦法
下面是兩種方法
第一種方法 使用$gonghui = iconv("gb2312","UTF-8",$gonghui);
第二種方法
** * 多字節(jié)字符串編碼轉(zhuǎn)換函數(shù) * * @param string str 需要進(jìn)行編碼轉(zhuǎn)換的字符串 * @param string to_encoding 指定轉(zhuǎn)換為某種編碼,如:gb2312、gbk、utf-8等 * @param mixed from_encoding 混合指定原來字串的編碼,如:同時指定 JIS, eucjp-win, sjis-win 混合編碼 * @return string string mb_convert_encoding ( string str, string to_encoding [, mixed from_encoding] ) **/
mb_convert_encoding 函數(shù)為php內(nèi)部多字節(jié)字符串編碼轉(zhuǎn)換函數(shù),可以在有需要的使用場合,幾乎支持所有編碼。PHP >= 4.0.6、 5 版本支持。
直接獲取 reg.php?gh=某某;
//工會登入?yún)?$gonghui = $_GET['gh'];
獲得的$gonghui 為gb2312編碼 輸出到utf-8網(wǎng)頁上顯示亂碼
改成
//工會登入?yún)?shù) $gonghui = $_GET['gh']; $gonghui = mb_convert_encoding($gonghui, "UTF-8", "gb2312");
就顯示正常了
對整個頁面進(jìn)行轉(zhuǎn)換
該方法適用所有編碼環(huán)境。這樣把前128個字符以外(顯示字符)的字符集都用 NCR(Numeric character reference,如“漢字”將轉(zhuǎn)換成“汉字”這種形式)來表示,這樣的編碼在任意編碼環(huán)境下頁面都能正 常顯示。
在php文件的頭部加上下面三行代碼:
mb_internal_encoding("gb2312"); // 這里的gb2312是你網(wǎng)站原來的編碼 mb_http_output("HTML-ENTITIES"); ob_start('mb_output_handler');
使用mb_convert_encoding 函數(shù)需啟用PHP 的mbstring (multi-byte string)擴(kuò)展。
如果沒有沒有開啟php的mbstring擴(kuò)展,則需要做如下設(shè)置,讓php支持該擴(kuò)展。
1、windows 服務(wù)器環(huán)境
編輯 php.ini 文件,將; extension=php_mbstring.dll 前面的 ; 去掉,重啟網(wǎng)頁服務(wù)器。
2、Linux服務(wù)器環(huán)境
在編譯配置時加入 --enable-mbstring=cn 編譯參數(shù),再進(jìn)行PHP的編譯安裝。
以上是php用get方法從url上獲取中文亂碼的解決辦法的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!