本文實例講述了PHP采用get獲取url漢字出現亂碼的解決方法。分享給大家供大家參考。具體方法如下:
一、問題:
本來打算這樣使用
復制代碼 代碼如下:<a href="list.php?plate=轄區動態" charset="utf-8" target="main">[查看轄區動態]</a>
結果在list.php頁面得到的是—–查看[轄區動怿]
一開始猜想可能是漢字的“態"這個編碼和某些東西沖突了,所以出現亂碼。
二、解決方法:
使用:
復制代碼 代碼如下:<a href="list.php?plate=<?php echo urlencode("轄區動態");?>" charset="utf-8" target="main">[查看]</a>
然後在list.php頁面這樣用
復制代碼 代碼如下:
<?php
header("Content-type: text/html; charset=utf-8");
if($_GET['plate'])
echo $plate=urldecode($_GET['plate']);
?>
也就不會亂碼和傳遞不正常了。
注意此處的接收GET頁面編碼需要和發送端一致!
關於string urlencode ( string $str )函數
此函數便於將字符串編碼並將其用於 URL 的請求部分,同時它還便於將變量傳遞給下一頁。
示例1 urlencode()
復制代碼 代碼如下:<?php
echo '<a href="mycgi?foo=', urlencode($userinput), '">';
?>
示例2 urlencode() 與 htmlentities()
復制代碼 代碼如下:<?php
$query_string = 'foo=' . urlencode($foo) . '&bar=' . urlencode($bar);
echo '<a href="mycgi?' . htmlentities($query_string) . '">';
?>
希望本文所述對大家的PHP程序設計有所幫助。