FOSUserBundle电子邮件重置链接无法指向正确的页面

时间:2016-03-23 06:37:19

标签: symfony fosuserbundle

我正在使用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

1 个答案:

答案 0 :(得分:2)

问题是token_ttl被设置为0意味着令牌立即过期,因此用户永远无法重置其密码。我最初设置为0以绕过FOSUserBundle'每24小时仅重置一次密码',但这是不正确的。

删除此行可修复我的问题。