Django小技巧10: 自定义认证策略
Posted October 26, 2018
翻译整理自: simpleisbetterthancomplex.com
Django 内置了一套功能极全的认证系统,而且可以很容易的进行自定义, 本章的内容就是自定义认证策略。
对于内置的login视图,Django 使用django.contrib.auth.forms.AuthenticationForm
来处理身份验证过程。 这个认证检查了基本的username
, password
和is_active
标识.
Django 可以通过AuthenticationForm
的confirm_login_allowed(user)
方法, 轻松添加自定义认证.
假设你想通过双重的电子邮件认证, 只有用户点击确认邮件后才可以登录,那么你可以这样做:
很简单, 只需覆盖confirm_login_allowed
方法,并在 urlconf 替换新的表单CustomAuthenticationForm
即可。你可以在confirm_login_allowed
添加任何的代码策略, 需要注意的是, 如果认证失败仅能抛出ValidationError
才可以正常工作.