Vue + Django 2.0.6 学习笔记 7.1 drf的token登录
程序员文章站
2022-07-14 22:38:13
...
DRF 使用的是TokenAuthentication 以前用template渲染的哪种登录方式是用SessionAuthentication 一般浏览器是采用这种的。但是前后端分离的话因为是跨站的。所以几乎不采用Session的方式 。
要杂用呢?
首先要把这种认证方式加入到应用中:
settings.py:
REST_FRAMEWORK = {
# 这条是之前的
'DEFAULT_PAGINATION_CLASS': 'rest_framework.pagination.PageNumberPagination',
# 这条是新加的
'DEFAULT_AUTHENTICATION_CLASSES': (
'rest_framework.authentication.BasicAuthentication',
'rest_framework.authentication.SessionAuthentication',
'rest_framework.authentication.TokenAuthentication',
)
}
INSTALLED_APPS = [
'rest_framework.authtoken'
]
urls.py
from rest_framework.authtoken import views
urlpatterns = [
path('api-token-auth/', views.obtain_auth_token)
]
然后makemigration和migrate
然后数据库中就有了这个表
表中的数据刚开始是空的
因为之前创建的用户没有经过token认证创建key所以是空的。 那咋办
通过postman来发送用户名和密码 让TokenAuthentication自动创建key
点击send之后在软件下方会返回token的key值
这时候再去查数据库表就有了该值。
原理:
urls.py:
from rest_framework.authtoken import views
path('api-token-auth/', views.obtain_auth_token)
# 通过rest_framework.authtoken.views.obtain_auth_token 找到对应类:
obtain_auth_token = ObtainAuthToken.as_view()
#然后找到ObtainAuthToken这个类
看下面那个post请求 它接收数据后进行校验(serializer_class = AuthTokenSerializer 这是校验对象)如果校验账号密码没问题则查询是否有token, 没有的话就创建一个token (token, created = Token.objects.get_or_create(user=user))
7.1 完结