0

在对照我的数据库检查 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

4

1 回答 1

0

好的问题解决了。恐怕这与我的 PDO 数据库连接有关。我没有更新代码来强制使用 UTF-8:

// Connect to database
$db = new PDO("mysql:host=" . DB_HOST . ";dbname=" . DB_NAME . ";charset=utf8", DB_USER, DB_PASS, array(PDO::MYSQL_ATTR_INIT_COMMAND => "SET NAMES 'utf8'"));

// Injection prevention
$db->setAttribute(PDO::ATTR_EMULATE_PREPARES, false);
$db->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

为浪费任何人的时间看这个道歉。这是我自己愚蠢的错!

于 2012-09-20T10:56:24.393 回答