這篇文章主要介紹了關於js和php對url編碼的處理方法,需要的朋友可以參考下
解決辦法: 采用js對URL中的漢字進行escape編碼。 代碼如下: <a href="" onclick="window.open('product_list.php?p_sort='+escape('PHP開發資源網'));"> 這樣點擊鏈接後的效時: 引用:http://127.0.0.1/shop/product_list.php?p_sort=PHP%u5F00%u53D1%u8D44%u6E90%u7F51 生成了這樣的效果, 很明顯用PHP的urldecode()或者base64_decode()是無法反解的。 解決方法, 用PHP寫一個反解函數: 代碼如下: function js_unescape($str){ $ret = ''; $len = strlen($str); for ($i = 0; $i < $len; $i++){ if ($str[$i] == '%' && $str[$i+1] == 'u'){ $val = hexdec(substr($str, $i+2, 4)); if ($val < 0x7f) $ret .= chr($val); else if($val < 0x800) $ret .= chr(0xc0|($val>>6)).chr(0x80|($val&0x3f)); else $ret .= chr(0xe0|($val>>12)).chr(0x80|(($val>>6)&0x3f)).chr(0x80|($val&0x3f)); $i += 5; } else if ($str[$i] == '%'){ $ret .= urldecode(substr($str, $i, 3)); $i += 2; } else $ret .= $str[$i]; } return $ret; } 注意JS編碼會自動轉換成為UTF-8, 所以必須進行編碼轉換才能得到正確的結果,否則會中文亂碼。 代碼如下: print iconv('utf-8', 'gb2312', js_unescape($_REQUEST['p_sort'])); 到此我們就成功地反解了js的escape編碼了。 另外我找到個用PHP實現js的escape編碼的函數: 代碼如下: function phpescape($str){ $sublen=strlen($str); $retrunString=""; for ($i=0;$i<$sublen;$i++){ if(ord($str[$i])>=127){ $tmpString=bin2hex(iconv("gb2312","ucs-2",substr($str,$i,2))); //$tmpString=substr($tmpString,2,2).substr($tmpString,0,2);window下可能要打開此項 $retrunString.="%u".$tmpString; $i++; } else { $retrunString.="%".dechex(ord($str[$i])); }} return $retrunString; }