我目前正在将一个 2.0.* 项目迁移到 Symfony 当前的 2.1 beta 版本。
在我的功能测试中,我目前有此代码来创建具有身份验证的客户端:
$client = // create a normal test client
$role = 'ROLE_USER';
$firewallName = 'main';
$user = // pull a user from db
$client->getCookieJar()->set(new \Symfony\Component\BrowserKit\Cookie(session_name(), true));
$token = new UsernamePasswordToken($user, null, $firewallName, array($role));
self::$kernel->getContainer()->get('session')->set('_security_' . $firewallName,
serialize($token));
这在 2.0.* 中按预期工作,但在 2.1 中没有,数据未在会话中设置。
有任何想法吗?
编辑(添加更多信息):
似乎问题出在方法“ onKernelResponse ”中的文件“ Symfony\Component\Security\Http\Firewall\ContextListener ”中。有这个代码:
if ((null === $token = $this->context->getToken()) || ($token instanceof AnonymousToken)) {
$session->remove('_security_'.$this->contextKey);
} else {
$session->set('_security_'.$this->contextKey, serialize($token));
}
在我的情况下,如果“$token instanceof AnonymousToken”为真,因此会话密钥被删除。如果我注释掉该代码,一切都会按预期工作。
所以我想我的新问题是:我该怎么做才能使令牌不匿名?