在对照我的数据库检查 URL 之前,我有以下代码行来检索和解码 URL:
$urls = url_split(url_current());
$url_page = (string)rawurldecode($url[0]);
使用以下函数将 URL 拆分并放入数组中:
function url_current ()
{
// Check for HTTPS
$http = 'http';
if (isset($_SERVER["HTTPS"]) && $_SERVER["HTTPS"] == "on") $http .= 's';
$http .= '://';
// Return URL
return $http . $_SERVER['HTTP_HOST'] . $_SERVER["REQUEST_URI"];
}
function url_split ($url)
{
// Retrieve URLs - Remove URL and split into array
$url = explode('/', str_replace('http://www.siteurl.com', '', $url));
// Build new array, remove blanks
$urls = array();
for ($i = 0; $i < sizeof($url); $i++)
{
if ($url[$i] != '') $urls[] = $url[$i];
}
// Return array
return $urls;
}
这适用于我的本地服务器(使用 Zend),但它不适用于我的实时服务器。这不应该是 $_SEVER 变量的问题,因为它们都返回了正确的数据。我不知道为什么与我的实时服务器相比,这在我的本地服务器上的表现会有所不同。php ini 中是否有任何设置可能导致这种情况?
在我的本地服务器上yrj%C3%B6laitinen产生yrjölaitinen但在我的实时服务器上产生yrjölaitinen。