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

flask处理token的装饰器

以下是在 Flask 中基于 token 实现的登录验证装饰器的示例代码:

import jwt
from functools import wraps
from flask import request, jsonify, current_appdef login_required(f):@wraps(f)def decorated_function(*args, **kwargs):token = request.headers.get('Authorization')if not token:return jsonify({'message': 'Missing token'}), 401try:data = jwt.decode(token, current_app.config['SECRET_KEY'], algorithms=['HS256'])current_user = data['username']except Exception as e:return jsonify({'message': 'Invalid token'}), 401return f(current_user, *args, **kwargs)return decorated_function

该装饰器首先检查请求头中是否存在 Authorization 字段,并解码其中的 token。如果没有找到 token,则返回一个包含错误消息的 JSON 响应。如果找到了 token,则使用 JWT 对其进行解码,同时使用 Flask 的 current_app 对象获取 SECRET_KEY。如果解码成功,那么装饰器会将解码出来的用户名传递给被装饰函数。如果解码失败,则返回一个包含错误消息的 JSON 响应。可以在需要登录验证的视图函数上添加该装饰器,例如:

@app.route('/protected')
@login_required
def protected(current_user):return jsonify({'message': 'This is a protected endpoint for user {}'.format(current_user)})

在上述代码中,protected 视图函数被 @login_required 装饰器进行修饰,当用户成功登录后,该视图函数会返回一个包含当前用户信息的 JSON 响应。需要注意的是,已经登录的用户才能访问该视图函数,否则将返回一个包含错误消息的 JSON 响应。

不过以上内容中涉及了解密参数,如果token并未进行加密可以按照如下方式写:

from functools import wraps
from flask import request, jsonify
def login_required_token(f):@functools.wraps(f)def decorated_function(*args, **kwargs):token = request.headers.get('Authorization')if not token:return jsonify({'message': 'Missing token'}), 401return f(*args, **kwargs)return decorated_function
@app.route('/logaudit/program/', methods=["POST"])
@login_required_token
def program_log():# print("#"*50)# print("current user is:",current_user)return makeresponse("首页")
http://www.lryc.cn/news/117048.html

相关文章:

  • 【Express.js】页面渲染
  • 2.UE数字人语音交互(UE数字人系统教程)
  • C语言——水仙花数字
  • java中list对象拷贝至新的list对象并保持两个对象独立的方法
  • 使用AI工具Lama Cleaner一键去除水印、人物、背景等图片里的内容
  • 瑞数系列及顶像二次验证LOGS
  • Anaconda版本和Python版本对应关系(持续更新...)
  • vscode 搭建STM32开发环境
  • 6款好用的思维导图在线制作网站盘点,拒绝低效、探索创意!
  • js的Promise
  • 2.4g无线芯片G350规格书详细介绍
  • React中使用mobx管理状态数据使用样例
  • 《HeadFirst设计模式(第二版)》第五章代码——单例模式
  • Linux: network: tools: tcpdump,抓取vlan包需要注意的事情;不然会出现LLC协议
  • 大数据离线阶段01:Apache Zookeeper
  • 数字孪生轨道交通,地铁视频孪生三维可视化管控平台
  • 自定义注解(Annontation)
  • 基于粒子群改进BP神经网络的血压评估系统,血压预警系统,pso-bp神经网络
  • Vue中引入外部css导致的全局污染
  • 【安装部署】Mysql下载及其安装的详细步骤
  • 如何循环执行windows和linux上的控制台指令
  • 【Shell】基础语法(三)
  • linux 服务开机自启
  • 【LeetCode】870 . 优势洗牌
  • 现代C++中的从头开始深度学习【2/8】:张量编程
  • uniapp软键盘谈起遮住输入框和头部被顶起的问题解决
  • 安防监控视频汇聚EasyCVR平台的FLV视频流在VLC中无法播放的原因排查
  • 虹科新闻 | 虹科与Power-MI正式建立合作伙伴关系
  • Xamarin.Android实现加载中的效果
  • Leetcode.1559 二维网格图中探测环