原地址: http://www.zu14.cn/2008/12/13/wordpress_iis_cn/
由於IIS在解析URL時,對於路徑中的utf-8編碼內容,會將其轉換成GBK編碼,這樣就導致在WordPress中,對$_SERVER[’PATH_INFO’]和$_SERVER[’REQUEST_URI’]取值時取到的是GBK編碼的url,但是WordPresss預設是用UTF-8編碼的,所以中文就轉成了亂碼,再用作SQL參數去資料庫查詢的時候就找不到記錄了。
解決方案:
找到 wp-includes\classes.php 這個檔案,先備份一個。開啟這個檔案,找到
<?php//...if ( isset($_SERVER['PATH_INFO']) ) $pathinfo = $_SERVER['PATH_INFO'];else $pathinfo = '';$pathinfo_array = explode('?', $pathinfo);$pathinfo = str_replace("%", "%25", $pathinfo_array[0]);$req_uri = $_SERVER['REQUEST_URI'];//...?>
自己對 $pathinfo 和 $req_uri 做一個 GBK --> UTF-8 編碼轉換
<?php//...if ( isset($_SERVER['PATH_INFO']) ) $pathinfo = mb_convert_encoding($_SERVER['PATH_INFO'], 'UTF-8', 'GBK');else $pathinfo = '';$pathinfo_array = explode('?', $pathinfo);$pathinfo = str_replace("%", "%25", $pathinfo_array[0]);$req_uri = mb_convert_encoding($_SERVER['REQUEST_URI'], 'UTF-8', 'GBK');//...?>
這樣操作,會有一些效能損耗,畢竟編碼轉換需要耗費系統資源的。
同時要求,PHP開啟了 mb_string