Django如何使用jwt获取用户信息

作者:小陆同学 时间:2022-07-06 10:08:34 

HTTP请求是无状态的,我们通常会使用cookie或session对其进行状态保持,cookie存储在客户端,容易被用户误删,安全性不高,session存储在服务端,在服务器集群情况下需要解决session不共享的问题,常用的解决方案有4种:客户端Cookie保存、服务器间Session同步、使用集群管理Session、把Session持久化到数据库。

jwt:json web token

在用户注册登录后,记录用户登录状态,我们可以用cookie和session来做状态保持,cookie存储在客户端,安全性低,session存储在服务器端,安全性高,但是在分布式架构中session不能同步化,所以我们用jwt来验证接口安全

组成:头部 载荷 签证

Jwt服务端不需要存储token串,用户请求时携带着经过哈希加密和base64编码后的字符串过来,服务端通过识别token值判断用户信息、过期时间等信息,在使用期间内不可能取消令牌或更改令牌权限。

jwt的安装与配置


# 安装 pip install djangorestframework-jwt
From rest_framework_jwt.authentication import JSONWebTokenAuthentication
Settings.py
INSTALLED_APPS = [
 '''
 'rest_framework.authtoken',
 '''
]
################### 2、配置jwt验证 ######################
REST_FRAMEWORK = {
 # 身份认证
 'DEFAULT_AUTHENTICATION_CLASSES': (
   'rest_framework_jwt.authentication.JSONWebTokenAuthentication',
   'rest_framework.authentication.SessionAuthentication',
   'rest_framework.authentication.BasicAuthentication',
 ),
}
import datetime

JWT_AUTH = {
 'JWT_AUTH_HEADER_PREFIX': 'JWT',
 'JWT_EXPIRATION_DELTA': datetime.timedelta(days=1),
}
AUTH_USER_MODEL='app.User' # 指定使用APP中的 model User进行验证

在django中,我们用内置的User表做登录功能


from rest_framework_jwt.views import obtain_jwt_token # 验证密码后返回token
urlpatterns = [
 re_path(r'v1/login/$', obtain_jwt_token,name='login'), # 用户登录后返回token
]

前端获取到token并且setitem

var token = 'JWT ' + data.token
localStorage.setItem('token', token);

在我们封装的 * 里有请求 * 和响应 * ,需要在每次发起请求的时候获取token


import Axios from 'axios'
import { Toast } from 'vant';
import URLS from '../../config/urls'

//1、使用自定义配置新建一个 axios 实例
const instance = Axios.create({
 baseURL: URLS.API_URL,
 responseType: 'json',
});

//2、添加请求 * :每次发送请求就会调用此 * ,添加认证token
instance.interceptors.request.use(
 config => {
   //发送请求前添加认证token,
   console.log(localStorage.getItem('token'))
   config.headers.Authorization = localStorage.getItem('token');  # 获取token
   // config.headers.Authorization = sessionStorage.getItem('token')
   return config
 },
 err => {
   return Promise.reject(err)
 });

// 3、响应 *
instance.interceptors.response.use(
 response => {
   if (response.status === 200) {
     return Promise.resolve(response);
   } else {
     return Promise.reject(response);
   }
 },
 // 服务器状态码不是200的情况
 error => {
   if (error.response.status) {
     switch (error.response.status) {
       // 401: 未登录
       // 未登录则跳转登录页面,并携带当前页面的路径
       // 在登录成功后返回当前页面,这一步需要在登录页操作。
       case 401:
         router.replace({
           path: '/login',
           query: { redirect: router.currentRoute.fullPath }
         });
         break;
       // 403 token过期
       // 登录过期对用户进行提示
       // 清除本地token和清空vuex中token对象
       // 跳转登录页面
       case 403:
         Toast({
           message: '登录过期,请重新登录',
           duration: 1000,
           forbidClick: true
         });
         // 清除token
         localStorage.removeItem('token');
         store.commit('loginSuccess', null);
         // 跳转登录页面,并将要浏览的页面fullPath传过去,登录成功后跳转需要访问的页面
         setTimeout(() => {
           router.replace({
             path: '/login',
             query: {
               redirect: router.currentRoute.fullPath
             }
           });
         }, 1000);
         break;
       // 404请求不存在
       case 404:
         Toast({
           message: '网络请求不存在',
           duration: 1500,
           forbidClick: true
         });
         break;
       // 其他错误,直接抛出错误提示
       default:
         Toast({
           message: error.response.data.message,
           duration: 1500,
           forbidClick: true
         });
     }
     return Promise.reject(error.response);
   }
 }
);

export default instance

这样即完成了jwt接口安全的认证

那么在python后端如何去获取jwt并提取我们需要的信息呢?


from rest_framework_jwt.authentication import JSONWebTokenAuthentication
from rest_framework.views import exception_handler
from rest_framework_jwt.utils import jwt_decode_handler
# 获取登陆的用户
   token = request.META.get('HTTP_AUTHORIZATION')[4:]
   token_user = jwt_decode_handler(token)

user_id = token_user['user_id'] # 获取用户id
这个方法不用在前端封装getitem token

或者从前端传过来token然后获取
.vue
var formdata = {
             id : this.$route.params.id,  // 获取/id
                 // this.$route.query.subid 获取?subid=id
             token: localStorage.getItem('token'),
           }
           postCreate(formdata).then(resp=>{
             console.log(resp)
             alert(resp.mes)
           }).catch(err=>{
             alert(err)
             console.log(err)
           })
         }
python views.py
def post(self,request):
data = request.data   # 获取post方法的数据
   # print(data)
   token = data.get('token')[4:]
   toke_user = jwt_decode_handler(token)
   user_id = toke_user['user_id']  
def get(self,request):
data = request.query_params # 获取get方法的参数

来源:https://www.cnblogs.com/lutt/p/11154902.html

标签:Django,jwt,用户,信息
0
投稿

猜你喜欢

  • Python基于Pymssql模块实现连接SQL Server数据库的方法详解

    2024-01-15 03:13:17
  • python通过对字典的排序,对json字段进行排序的实例

    2023-06-15 02:20:40
  • asp GetString的用法

    2008-06-12 13:46:00
  • Mysql InnoDB引擎中页目录和槽的查找过程

    2024-01-14 09:32:28
  • python机器基础逻辑回归与非监督学习

    2023-03-17 03:59:05
  • 用Python生成HTML表格的方法示例

    2023-10-16 02:27:34
  • SQL Server自动更新统计信息的基本算法

    2012-10-07 11:02:50
  • Python3学习urllib的使用方法示例

    2021-09-23 00:08:08
  • pycharm 如何跳出服务器证书不受信任的提示

    2022-01-15 16:38:46
  • Python中使用copy模块实现列表(list)拷贝

    2022-05-13 02:46:48
  • HTML与javascript中常用编码浅析

    2008-12-23 12:20:00
  • 如何恢复数据库的账号 登录名/用户名等

    2024-01-25 08:08:47
  • Python中TypeError:unhashable type:'dict'错误的解决办法

    2022-05-09 19:57:41
  • Python实现的远程文件自动打包并下载功能示例

    2021-03-25 04:45:51
  • scala中停止循环的三种方式(推荐)

    2023-03-20 07:03:34
  • Ajax缓存和编码问题的最终解决方案

    2010-03-30 13:42:00
  • 如何用Python绘制棒棒糖图表

    2021-05-02 06:26:33
  • python+Word2Vec实现中文聊天机器人的示例代码

    2023-08-04 13:11:29
  • 最简洁的多重查询的解决方案

    2008-03-02 15:51:00
  • 使用Python批量压缩tif文件操作步骤

    2021-03-27 00:04:10
  • asp之家 网络编程 m.aspxhome.com