小編給大家分享一下php用get方法從url上獲取中文亂碼的解決辦法,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
php get參數亂碼的解決辦法:1、使用“iconv("gb2312","UTF-8",$gonghui);”方法解決亂碼問題;2、通過“mb_convert_encoding ”方法解決亂碼問題。
php用get方法從url上獲得的中文亂碼解決辦法
下面是兩種方法
第一種方法 使用$gonghui = iconv("gb2312","UTF-8",$gonghui);
第二種方法
** * 多字節字符串編碼轉換函數 * * @param string str 需要進行編碼轉換的字符串 * @param string to_encoding 指定轉換為某種編碼,如: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 函數為php內部多字節字符串編碼轉換函數,可以在有需要的使用場合,幾乎支持所有編碼。PHP >= 4.0.6、 5 版本支持。
直接獲取 reg.php?gh=某某;
//工會登入參 $gonghui = $_GET['gh'];
獲得的$gonghui 為gb2312編碼 輸出到utf-8網頁上顯示亂碼
改成
//工會登入參數 $gonghui = $_GET['gh']; $gonghui = mb_convert_encoding($gonghui, "UTF-8", "gb2312");
就顯示正常了
對整個頁面進行轉換
該方法適用所有編碼環境。這樣把前128個字符以外(顯示字符)的字符集都用 NCR(Numeric character reference,如“漢字”將轉換成“汉字”這種形式)來表示,這樣的編碼在任意編碼環境下頁面都能正 常顯示。
在php文件的頭部加上下面三行代碼:
mb_internal_encoding("gb2312"); // 這里的gb2312是你網站原來的編碼 mb_http_output("HTML-ENTITIES"); ob_start('mb_output_handler');
使用mb_convert_encoding 函數需啟用PHP 的mbstring (multi-byte string)擴展。
如果沒有沒有開啟php的mbstring擴展,則需要做如下設置,讓php支持該擴展。
1、windows 服務器環境
編輯 php.ini 文件,將; extension=php_mbstring.dll 前面的 ; 去掉,重啟網頁服務器。
2、Linux服務器環境
在編譯配置時加入 --enable-mbstring=cn 編譯參數,再進行PHP的編譯安裝。
以上是php用get方法從url上獲取中文亂碼的解決辦法的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。