首页 文章

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

提问于
浏览
0

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

  • 2

    问题是 token_ttl 设置为0意味着令牌立即过期,因此用户永远无法重置其密码 . 我最初设置为0以绕过带有FOSUserBundle的'only reset your password once every 24 hours',但这是不正确的 .

    删除此行修复了我的问题 .

相关问题