2

您好,我正在创建一个网站,当用户添加 amps 或斜杠作为他提交的文章的标题时,我遇到了 htaccess clean url 重定向问题。我决定只允许特定字符,如字母数字、-、_ ,@,[,]。没有引号或双引号等...

我似乎无法使正则表达式工作我对正则表达式没有很好的经验,而不是使用字符串替换我想我应该问。

也将不胜感激有关此问题的任何其他建议

在我的 htaccess 中,我有以下设置:

RewriteRule ^([^/]*)(.*)$ /index.php?page=$1&request=$2

在我的索引中,我有:

include 'db.php';
include 'generic.php';

$pages = array('','main','events','news','rss','search','add-event');

if(isset($_GET['page']) && in_array($_GET['page'], $pages))
{
    $event_category = null;
    $event_title = null;
    $search_string = null;
    $rss_category = null;
    $events_date = null;
    $search_page = null;

    validate_evented_page(trim(urldecode($_GET['page'])));
}
else
{
    evented_error_page(404);
}

function evented_error_page($err)
{
    include('errorpages/error.php');
}

function validate_evented_page($p)
{
    $page = strtolower($p);

    global $event_category;
    global $event_title;
    global $search_string;
    global $rss_category;
    global $events_date;
    global $search_page;

    if($page == 'main' || strlen($p) == 0)
    {   
        include 'main.php';
    }
    else if($page == 'events')
    {
        $params = explode_url($_GET['request']);

        if(count($params) == 0)
        {
            $events_date = "'';";
            include 'allevents.php';
        }
        else if(count($params) == 1)
        {   

            if(check_date($params[0]))
            {
                $date_split = explode('-',$params[0]);
                $events_date = "'".date("m/d/Y" , mktime(0, 0, 0, date('m'), $date_split[1], date('Y')))."';";
            }
            else
            {
                $events_date = "'';";
            }

            include 'allevents.php';
        }
        else if(count($params) == 2)
        {
            $event_category = trim(urldecode($params[0]));
            $event_title = trim(urldecode($params[1]));

            include 'event.php';
        }
        else
        {
            evented_error_page(404);
        }

    }
}

以下网址:

/events/Drum+%26+Bass/Innersense+presents+ETHOS_v04-0

给出 $_GET['request'] = /Drum

什么时候应该是 Drum & Bass(在数据库中,我将此类别存储为“Drum & Bass”)。

4

1 回答 1

0

您需要告诉 mod_rewrite使用标志&对在反向引用中分组的内容进行编码:B

RewriteRule ^([^/]*)(.*)$ /index.php?page=$1&request=$2 [B,L]

URI 在通过重写引擎发送时被解码。所以%26被解码为&B标志确保它被重新编码为反向引用。

于 2012-12-14T13:01:27.173 回答