我想针对数据库创建SF2身份验证,我使用SF2的官方文档,http://symfony.com/doc/2.0/cookbook/security/entity_provider.html,问题是检查不起作用,我不知道,我没有得到任何错误,输入用户信息后,我仍然在同一页面/登录,没有错误,我真的没有得到它。
security.yml
security:
encoders:
TEST\UserBundle\Entity\User:
algorithm: sha512
encode-as-base64: true
iterations: 10
role_hierarchy:
ROLE_ADMIN: ROLE_USER
ROLE_SUPER_ADMIN: [ROLE_USER, ROLE_ADMIN, ROLE_ALLOWED_TO_SWITCH]
providers:
main:
entity: { class: TESTUserBundle:User, property: username }
firewalls:
login:
pattern: ^/(login|reset|accueil)
anonymous: true
main:
pattern: /.*
form_login:
check_path: /check_login
login_path: /login
logout:
path: /logout
target: /login
security: true
anonymous: false
access_control:
#- { path: ^/login, roles: IS_AUTHENTICATED_ANONYMOUSLY, requires_channel: https }
#- { path: ^/_internal, roles: IS_AUTHENTICATED_ANONYMOUSLY, ip: 127.0.0.1 }
#- { path: ^/admin, roles: ROLE_ADMIN }
问题是错误总是为null,这是我的登录表单
{% if error == 1 %}
<span class="pw-alert">E-mail et/ou mot de passe erroné(s)</span>
{% endif %}
<form action="{{ path('_security_check_user') }}" method="POST">
<div>
<label for="username">Username:</label>
<input type="email" id="username" name="_username" value="{{ last_username }}" />
</div>
<div>
<label for="password">Password:</label>
<input type="password" id="password" name="_password" />
</div>
<input type="submit" value="Se connecter" name="login"/>
</div>
</form>
答案 0 :(得分:0)
check_path应该是/login_check
而不是/check_login
(适用于我)。
对于提供者,请尝试以这种方式指示您的类:TEST\UserBundle\Entity\User
(因为您要从数据库中记录它们,您必须提供用户实体的路径,而不是用户控制器)。并将provider: main
添加到主防火墙。
有帮助吗?