我正在第一次使用 Symfony2 开发一个由 Doctrine2 支持的小型项目。目前,我正在为 symfony2 的安全组件而苦苦挣扎,确切地说是文档中描述的身份验证机制。
我想使用基于表单的身份验证并执行文档中所述的所有操作:
我有一个 security.yml 配置文件,如下所示:
security.config:
firewalls:
admin:
pattern: /admin/.*
form-login: true
logout: true
login_path: /login
check_path: /validateLogin
always_use_default_target_path: false
target_path_parameter: target
check_page:
pattern: /validateLogin
form-login: true
login_path: /login
check_path: /validateLogin
always_use_default_target_path: false
target_path_parameter: target
public:
pattern: /.*
security: false
providers:
admin:
password_encoder: md5
entity:
class: AdminBundle:User
property: username
access_control:
- { path: /admin/.*, role: ROLE_ADMIN }
- { path: /validateLogin, role: IS_AUTHENTICATED_ANONYMOUSLY }
role_hierarchy:
ROLE_ADMIN: ROLE_USER
在阅读了devcomments上的类似帖子后,check_page 被排除在“无安全”区域之外。
在我的路由配置中,我包含两个身份验证规则:
_security_login:
pattern: /login
defaults:
_controller: PublicBundle:Auth:index
_security_check:
pattern: /validateLogin
我用来表示用户的实体类是一个 Doctrine2 实体并实现了 AccountInterface:
<?php
namespace Application\AdminBundle\Entity;
use Symfony\Component\Security\User\AccountInterface;
/**
* @orm:Entity
*/
class User implements AccountInterface
{
/**
* @orm:Id
* @orm:Column(type="integer")
* @orm:GeneratedValue(strategy="IDENTITY")
*/
protected $id;
/**
* @orm:Column(type="string", length="255")
*/
protected $username;
/**
* @orm:Column(type="string", length="40")
*/
protected $password;
public function getId()
{
return $this->id;
}
public function setId($id)
{
$this->id = $id;
}
public function getUsername()
{
return $this->username;
}
public function setUsername($username)
{
$this->username = $username;
}
public function getPassword()
{
return $this->password;
}
public function setPassword($password)
{
$this->password = $password;
}
/**
* Implementing the AccountInterface interface
*/
public function __toString()
{
return $this->getUsername();
}
public function getRoles()
{
return array('ROLE_ADMIN');
}
public function eraseCredentials()
{
}
public function getSalt()
{
return $this->getId();
}
}
在 AuthController 类中,我使用 symfony2 文档中的示例代码:
public function indexAction()
{
if ($this->get('request')->attributes->has(SecurityContext::AUTHENTICATION_ERROR)) {
$error = $this->get('request')->attributes->get(SecurityContext::AUTHENTICATION_ERROR);
} else {
$error = $this->get('request')->getSession()->get(SecurityContext::AUTHENTICATION_ERROR);
}
return
$this->render(
'PublicBundle:Auth:index.twig',
array(
'last_username' => $this->get('request')->getSession()->get(SecurityContext::LAST_USERNAME),
'error' => $error));
}
现在问题来了:从http://symfony2.localhost/app_dev.php/admin/test到http://symfony2.localhost/app_dev.php/login的重定向规则有效,但是在输入用户名/密码并提交登录表单之后,我再次被重定向到登录 url 而没有错误消息。
我知道这可能是一个非常基本的问题,但是由于关于 symfony2 的文档还不是很多,我认为这是一个提出类似问题的好地方。一般来说,symfony2 项目中的一些要点似乎在神奇地工作(当然是 DI 支持的),这使得学习过程有点困难。我对身份验证如何工作的想法是,有一些神奇的控制器可以捕获 validateLogin 操作,为我的 User 实体查找实体存储库,调用 findOneBy('username' => $username) 并比较密码......是这样吗?对?
提前感谢您的任何提示,我已经在谷歌上搜索了这个问题几个小时了...... :)
保罗