我们的团队在后端使用 django-rest-api 进行项目,并在前端进行响应。
对于身份验证,我们使用 django-rest-auth,并且我们在密码重置方面遇到问题。
这里的网址:
urlpatterns += [
url(r'^accounts/', include('allauth.urls')),
url(r'^admin/', include(admin.site.urls)),
url(r'^api/', include('api.urls')),
url(r'^rest-auth/', include('rest_auth.urls')),
url(r'^rest-auth/registration/', include('rest_auth.registration.urls')),
url(
r'^rest-auth/password/reset/$',
PasswordResetView.as_view(),
name='password_reset',
),
url(r'^rest-auth/password/reset/confirm/(?P<uidb64>[0-9A-Za-z_\-]+)/(?P<token>[0-9A-Za-z]{1,13}-[0-9A-Za-z]{1,20})/$',
PasswordResetConfirmView.as_view(),
name='password_reset_confirm'),
url(
r'^rest-auth/registration/account-confirm-email/(?P<key>[-:\w]+)/$',
confirm,
name="account_confirm_email"
),
url(r'^', include('core.urls', namespace='core')),
]
当发布对 password_reset 的请求时,用户会收到包含 uid 和令牌的链接的电子邮件。然后用户在react表单中填写new_password,我们想要发布数据:
{
"new_password1": "new_password",
"new_password2": "new_password",
"uid": "",
"token": ""
}
到/rest-auth/password/reset/confirm/。
我们如何在前端获取此 uid 和令牌,以便在此 url 上创建确认密码重置的页面,然后发布数据以确认密码更改?