6-7认证和权限-DRF认证之jwt认证.pdfVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 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)

177****3106 + 关注
实名认证
文档贡献者

大学本科生

1亿VIP精品文档

相关文档