- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
6-7认证和权限-DRF认证之jwt认证
⽬录:
JWT认证介绍
JWT 认证环境准备
JWT 认证基本使⽤
JWT 认证权限
⼀、JWT 认证介绍
使⽤django rest framework 开发api并使⽤ json web token(JWT)进⾏⾝份验证,使⽤django-rest-framework-jwt这个库来帮助我们简单的使⽤jwt进⾏⾝份验证。
那我们⽤JWT认证有哪些优点和缺点呐?
优点:
⽆状态:JWT的token不会存在服务器中,它是存在客户端上的,这样我们就更好管理。
避免csrf :意思就是已经帮你封装好了,不需要在进⾏ csrf 验证。
⽐较适合给移动端提供 api
缺点:
注销登录后Token时效问题:因为token存在客户端上,所以就导致有时候,⽐如说我们修改密码,然后注销⽤户导致token还在有效期内,token还能继续使⽤。那么就没有办法控制
它。我们可以通过 redis缓存来解决这个问题。
⼆、JWT 认证环境准备
2.1、安装
pip install djangorestframework-jwt
2.2、注册
说明:在settings.py⽂件中的INSTALLED_APPS中注册 rest_framework.authtoken
INSTALLED_APPS = [
rest_framework,
rest_framework.authtoken, #注册
]
2.3、配置
说明:我们在settings.py中配置jwt认证,已经过期时间。当然这个是全局的。
# 全局配置 JWT 验证
REST_FRAMEWORK = {
DEFAULT_AUTHENTICATION_CLASSES: (
rest_framework_jwt.authentication.JSONWebTokenAuthentication, # 配置验证⽅式为Token验证
),
DEFAULT_PERMISSION_CLASSES: (
rest_framework.permissions.IsAuthenticated, #配置全局权限
)
}
#配置JWT的token的超时时间
JWT_AUTH = {
JWT_EXPIRATION_DELTA: datetime.timedelta(days=7), # Token 过期时间为⼀周
JWT_AUTH_HEADER_PREFIX: JWT, # Token的头为:JWT adashkjdhaskjh
JWT_ALLOW_REFRESH: False, #True允许刷新,False不允许刷新
}
2.4、路由
说明:其实JWT认证跟token认证⼀样,都需要在路由下配置 1个函数路由,⽣成 token值。
#根级路由
from django.contrib import admin
from django.urls import path, include
from rest_framework_jwt.views import obtain_jwt_token #导⼊⽣成路由函数
urlpatterns = [
path(admin/, admin.site.urls),
path(api/, include(app05.urls)),
path(api-token-auth/, obtain_jwt_token) #配置⽣成token路由
]
好咧!配置好了,我们来⽤ postman测试⼀下,看看能否⽣成⼀个 token值:
三、JWT 认证基本使⽤
3.1、增加返回信息
说明:我们的返回信息只有 token值,不能满⾜我们的需求,我们通过修改该视图的返回值可以完成我们的需求,⽐如说:我们在返回token的同时,我们还想返回 userid和username。以及
其他信息呐。所以在我们的应⽤中(app05)新建⼀个 utils.py ⽂件。
⽬录结构:
-app05(应⽤)
-migrations
...
-models.py
-admin.py
-permissions.py
文档评论(0)