让我在提出问题之前解释一下情况。我有一个网站domain.com。页面sub.domain.com要求用户登录才能访问。如果我允许访问提供其操作为domain.com/login的表单的sub.domain.com/login,则会将数据发送到domain.com/login并重定向回sub.domain.com/login。但是,如果我尝试访问sub.domain.com(需要身份验证),它会正确地重定向到domain.com/login,但在登录后不会重定向回sub.domain.com。我发现错误是未登录时重定向未发送引用标头。有没有办法让它成为如果用户试图访问需要身份验证的子域上的页面,它会将他重定向到domain.com/login,然后回到他原来的位置?
答案 0 :(得分:0)
重定向是否总是需要重定向回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来记录用户。
答案 1 :(得分:0)
好的,这一切都与路线有关。我终于能够通过在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);
}