我正在使用Symfony v2.6.13和FOSUserBundle
。
我正在使用FOSUserBundle在我的项目上实现用户身份验证。我正在使用自己的模板(树枝)来显示login/register/reset
密码等,方法是覆盖他们的模板(即将相同的文件名放入我的Project/app/Resources/FOSUserBundle/views
文件夹中)。如此处所述:https://symfony.com/doc/master/bundles/FOSUserBundle/overriding_templates.html
我面临的问题是我通过电子邮件收到的重置密码的链接将我带回原来的同一页面,即输入我的电子邮件/用户名的屏幕。电子邮件中生成的链接应该带我到一个屏幕,其中有两个文本框供我更改密码,但我从未看到此页面。
我不知道为什么会这样。
config.yml
fos_user:
db_driver: mongodb # other valid values are 'orm' mongodb', 'couchdb' and 'propel'
firewall_name: main
user_class: AppBundle\Document\User
registration:
form:
# using this because I am running Symfony 2.6
type: app_user_registration
resetting:
token_ttl: 0 # no restrictions on resetting password
email:
from_email:
address: Brendan@stackoverflow.com
sender_name: SenderName
service:
#default implementation, and uses Swiftmailer to send emails.
mailer: fos_user.mailer.default
因此,在电子邮件中,它将生成一个重置链接,例如:
http://127.0.0.1:8000/resetting/reset/59wonV9cK7UPR122rhNZQAXMJwoXUz7dt23_O-a4aJ4
(注意:在本地机器上测试)。
当我点击链接时,它会转到:
http://127.0.0.1:8000/resetting/reset
随后是屏幕,只允许我输入我的用户名或电子邮件以重置密码(即同一屏幕循环播放)。
非常感谢任何帮助。
编辑:
我正在使用FOSUserBundle提供的路线和我自己路线的注释。
应用程序/配置/ routing.yml中:
app_website:
resource: "@AppBundle/Resources/config/routing.yml"
prefix: /
app:
resource: "@AppBundle/Controller/"
type: annotation
fos_user:
resource: "@FOSUserBundle/Resources/config/routing/all.xml"
当检查我的路线($ php app / console route:debug)时,它们都是FOSUserBundle的默认路径:
fos_user_security_login GET|POST ANY ANY /login
fos_user_security_check POST ANY ANY /login_check
fos_user_security_logout GET ANY ANY /logout
fos_user_profile_show GET ANY ANY /profile/
fos_user_profile_edit GET|POST ANY ANY /profile/edit
fos_user_registration_register GET|POST ANY ANY /register/
fos_user_registration_check_email GET ANY ANY /register/check-email
fos_user_registration_confirm GET ANY ANY /register/confirm/{token}
fos_user_registration_confirmed GET ANY ANY /register/confirmed
fos_user_resetting_request GET ANY ANY /resetting/request
fos_user_resetting_send_email POST ANY ANY /resetting/send-email
fos_user_resetting_check_email GET ANY ANY /resetting/check-email
fos_user_resetting_reset GET|POST ANY ANY /resetting/reset/{token}
fos_user_change_password GET|POST ANY ANY /profile/change-password
答案 0 :(得分:2)
问题是token_ttl
被设置为0意味着令牌立即过期,因此用户永远无法重置其密码。我最初设置为0以绕过FOSUserBundle'每24小时仅重置一次密码',但这是不正确的。
删除此行可修复我的问题。