在我提出问题之前,让我先解释一下情况。我有个网站,domain.com。页面sub.domain.com需要用户登录才能访问。如果我允许访问sub.domain.com/login,它提供了一个操作为domain.com/login的表单,它将数据发送到domain.com/login并重定向回sub.domain.com/login。但是,如果我尝试访问登录(这需要身份验证),它会正确地重定向到domain.com/ sub.domain.com,但在登录后不会重定向回sub.domain.com。我发现错误是未登录时的重定向没有发送referrer报头。有没有办法使其在用户试图访问需要身份验证的子域上的页面时,它会将他重定向到domain.com/login,然后返回到他最初所在的位置?
发布于 2012-02-02 03:58:21
好吧,这一切都与路由有关。通过在我的routes.php文件中设置一个switch语句,我终于能够让它工作起来:
switch(Configure::read('subdomain'))
{
case 'subdomain':
Router::connect('/login', array('controller'=>'users', 'action'=>'login'));
}
并像这样设置我的引导程序:
preg_match('/^(?:www\.)?(?:(.+)\.)?(.+\..+)$/i', env('HTTP_HOST'), $matches);
$subdomain = empty($matches[1]) ? false : $matches[1];
if( strlen($subdomain) > 0 && $subdomain != "www" )
{
if($subdomain == 'api')
$_GET["url"] = $subdomain . "/" . (isset($_GET["url"]) ? $_GET["url"] : "");
Configure::write('subdomain', $subdomain);
}
发布于 2012-01-11 20:09:49
重定向总是需要重定向回sub.domain.com吗?如果是这样,我建议将AuthComponents loginRedirect属性设置为您希望用户重定向到的位置。查看此页面:http://book.cakephp.org/1.3/en/view/1270/loginRedirect
此外,该页面还表明CakePHP会自动将您在登录之前访问的控制器-操作对存储在会话中。因此,也许您还应该检查您的会话是否在domain.com和sub.domain.com之间共享。
最后一条评论:在登录后会发生什么?您是否被重定向到domain.com上的控制器/操作,或者根本没有被重定向?
注意:我假设您使用的是CakePHP 1.3,并使用AuthComponent让用户登录。
https://stackoverflow.com/questions/8816494
复制相似问题