我关注How to Add "Remember Me" Login Functionality,这应该是直截了当的,但不是这样。
我还检查了this question等。
我检查了登录表单是否正确发布了字段_remember_me
,但是Symfony不会以某种方式拦截它并创建cookie。
我去了课堂,我相信,它设置了cookie,/vendor/symfony/src/Symfony/Component/Security/Http/RememberMe/TokenBasedRememberMeService.php
,似乎那里没有任何事情发生。我尝试使用var_dump或者将一些构建cookie的参数放在会话变量上,但无济于事。
这样的登录工作正常。
我正在使用Guard Authenticator。
以下是代码:
security.yml
security:
encoders:
UsedBundle\Entity\User:
algorithm: bcrypt
providers:
db_provider:
entity:
class: UsedBundle:User
property: email
manager_name: used
firewalls:
dev:
pattern: ^/(_(profiler|wdt)|css|images|js)/
security: false
main:
anonymous: ~
provider: db_provider
form_login:
login_path: /
username_parameter: _email
check_path: /login_check
use_referer: true
guard:
authenticators:
- app.form_login_authenticator
logout:
path: /logout
target: /
remember_me:
secret: '%secret%'
secure: false #change this to true if HTTPS
access_control:
- { path: ^/admin, roles: ROLE_ADMIN }
- { path: ^/, roles: IS_AUTHENTICATED_ANONYMOUSLY }
登录表单:
{% if error is defined and error is not null %}
{{ dump(error) }}
<div>{{ error.messageKey|trans(error.messageData, 'security') }}</div>
{% else %}
<form action="" method="post" name="login_form" id="login_form" >
<div class="contact" >
<input type="email" id="email" name="_email" class="form-control" placeholder="e-mail" value="{% if last_username is defined %}{{ last_username }} {% endif %}" />
</div>
<div class="contact" >
<input type="password" id="password" name="_password" placeholder="mot de passe" />
</div>
<div id="captcha_signup"></div>
<div id="remember_me">
<label for="remember">Se souvenir de moi </label>
<input type="checkbox" id="remember_me" name="_remember_me" />
<p id="a_recovery">mot de passe oubliée?</p>
</div>
<div>
<button type="submit" class="sub_ok btn" name="submit" >Valider</button>
</div>
</form>
{% endif %}
答案 0 :(得分:0)
在[{1}}
中,AbstractFormLoginAuthenticator
或return true;
扩展的自定义身份验证器需要supportsRememberMe()
public function supportsRememberMe()
{
return true;
}
如果您的代码中已包含此代码,请从您进入登录页面并点击该提交按钮的那一刻开始分享您的完整身份验证器实现和dev.log输出。