当前位置: 首页 > news >正文

网站首页的head标签内谷歌浏览器下载app

网站首页的head标签内,谷歌浏览器下载app,哪个网站做数学题赚钱,简书 wordpress文章目录 JWT简介在Django中使用JWT1. 安装2. 配置3. 添加认证接口 客户端使用JWT1. 获取新token2. 调用API3. 刷新token 同步发布在个人站点:https://panzhixiang.cn JWT简介 JWT(JSON Web Token)是一种流行的跨域认证解决方案。它可以在令牌中安全地传输用户身份…

文章目录

  • JWT简介
  • 在Django中使用JWT
        • 1. 安装
        • 2. 配置
        • 3. 添加认证接口
  • 客户端使用JWT
      • 1. 获取新token
      • 2. 调用API
      • 3. 刷新token

同步发布在个人站点:https://panzhixiang.cn

JWT简介

JWT(JSON Web Token)是一种流行的跨域认证解决方案。它可以在令牌中安全地传输用户身份信息,实现无状态认证机制。

优点:

  • 跨域认证,适用于分布式微服务
  • 减少数据库查询,优化性能
  • 更好的托管和扩展性

结构:

header.payload.signature
  • header 中描述签名算法等元数据
  • payload 中包含自定义用户数据,如用户名、角色等
  • signature 通过头和载荷以及密钥签名,保证完整和可验证

这一部分具体内容可以参考:https://www.bilibili.com/video/BV1Sz4y1o7E8 我以前推荐过这个教程。

通过这种方式,JWT可以将用户信息安全地在客户端和服务端传递。

在Django中使用JWT

JWT在Django有多种第三方包可以实现,我这里选择使用比较常用的simplejwt.

1. 安装
pip install djangorestframework_simplejwt
2. 配置

在settings.py中添加以下内容:

INSTALLED_APPS = [ 
# ... 
'rest_framework', 
'rest_framework_simplejwt', 
# ... 
]REST_FRAMEWORK = {'DEFAULT_AUTHENTICATION_CLASSES': ['rest_framework_simplejwt.authentication.JWTAuthentication',]
}SIMPLE_JWT = {'ACCESS_TOKEN_LIFETIME': timedelta(minutes=30),'REFRESH_TOKEN_LIFETIME': timedelta(days=1),
}

注意: 这里还需要配置REST_FRAMEWORK本身的认证相关的配置

3. 添加认证接口

我们需要为获取tokens的视图配置URLs。这些视图已经被 djangorestframework_simplejwt 提供了,我们只需将其添加到urls.py文件即可:

from django.urls import path
from rest_framework_simplejwt.views import TokenObtainPairView, TokenRefreshViewurlpatterns = [# ...path('api/token/', TokenObtainPairView.as_view(), name='token_obtain_pair'),path('api/token/refresh/', TokenRefreshView.as_view(), name='token_refresh'),# ...
]

客户端使用JWT

1. 获取新token

发送用户名密码,获取access和refresh token:

`import requests 
url = '/api/token/' 
data = {'username': 'user1', 'password': 'secure-password'} 
response = requests.post(url, data=data) 
access_token = response.json()['access']  
refresh_token = response.json()['refresh']

保存token以供后续使用。

2. 调用API

在请求头中提供jwt token:

headers = {'Authorization': f'Bearer {access_token}'}response = requests.get('/api/user/', headers=headers)

3. 刷新token

access token过期后,使用refresh token获取新的access token:

url = '/api/token/refresh/'
data = {'refresh': refresh_token}response = requests.post(url, data=data)
new_access_token = response.json()['access']

重复步骤2,3即可使用新的token调用API。

至此,我们了解了如何在Django REST框架中集成JWT认证,实现基于token的API接口访问控制。JWT可以提供更强大的用户认证方案。

http://www.khdw.cn/news/11470.html

相关文章:

  • 北京给公司做网站多少钱晋中网络推广
  • 企业网站备案要求2023年9月疫情又开始了吗
  • 成都网站建设四川冠辰科技站长工具seo下载
  • 湖北网站推广公司技巧网站设计公司有哪些
  • 徐州公司网站制作企业网络营销推广方案策划范文
  • 上海影城改造升级昆明seo关键字推广
  • 网站调用网页怎么做网站推广方式有哪些
  • ps软件网站有哪些功能关键词挖掘查询工具爱站网
  • 公司网站设计案例公司做网站推广
  • 西安有哪些网站建设外包公司报个电脑培训班要多少钱
  • 网站制作维护发票郑州短视频代运营公司
  • WordPress主题DIY插件东莞seo推广
  • 兼职网站制作竞价推广的企业
  • 防录屏网站怎么做经济新闻最新消息财经
  • 中国合伙人2做的什么网站小说排行榜百度
  • 做响应式网站的微博号站长统计app进入网址
  • 自助下单网站惠州网站营销推广
  • 杭州响应式网站建设广告投放都有哪些平台
  • 网站管理系统制作自动外链
  • 曲阳县做网站淘宝指数查询入口
  • 那个网站教做菜做的好厦门seo全网营销
  • 网站模百度平台我的订单查询在哪里
  • 企业怎样选择域名做网站推广点击器
  • 龙岗网站建设培训百度百度
  • 2022年小规模企业所得税怎么征收seo专业培训seo专业培训
  • 兰山做网站杭州seo
  • react 手机网站开发seo人员是什么意思
  • 专业网站优化百度快照优化的优势是什么
  • 云主机怎么装网站发布外链
  • 如何制作免费网站百度推广账户登陆