Vue + Django 2.0.6 学习笔记 7.1 drf的token登录

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

然后数据库中就有了这个表

Vue + Django 2.0.6 学习笔记 7.1 drf的token登录_第1张图片

表中的数据刚开始是空的

因为之前创建的用户没有经过token认证创建key所以是空的。 那咋办

通过postman来发送用户名和密码 让TokenAuthentication自动创建key

Vue + Django 2.0.6 学习笔记 7.1 drf的token登录_第2张图片

点击send之后在软件下方会返回token的key值

Vue + Django 2.0.6 学习笔记 7.1 drf的token登录_第3张图片

这时候再去查数据库表就有了该值。

 

原理:

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这个类

Vue + Django 2.0.6 学习笔记 7.1 drf的token登录_第4张图片

看下面那个post请求 它接收数据后进行校验(serializer_class = AuthTokenSerializer 这是校验对象)如果校验账号密码没问题则查询是否有token, 没有的话就创建一个token (token, created = Token.objects.get_or_create(user=user))

7.1 完结

你可能感兴趣的:(Django,Django,drf登录)