Flask 统一拦截器

python 复制代码
import os
 
from flask import Flask, request, session
 
app = Flask(__name__)
app.config['SECRET_KEY'] = os.urandom(24)  # 生成24位的随机数种子,用于产生SESSION ID
 
 
@app.route('/article/<int:article_id>')
def test(article_id):
    """
    路由地址参数, 必须同步定义在接口函数里,作为形参
    """
    return f'你正在访问编号为:{article_id}的文章'
 
 
@app.route('/sess')
def sess():
    session['is_login'] = 'true'
    return 'done'
 
 
@app.before_request
def before():
    """
    针对app实例定义全局拦截器
    """
    url = request.path  # 读取到当前接口的地址
    if url == '/sess':
        pass
    elif session.get('is_login', '') != 'true':
        return '你还没有登录'
    else:
        pass
    
 
if '__name__' == '__main__':
    app.run()

模块拦截器

也叫视图拦截器,只针对某一个模块进行拦截,应用于Blueprint模块中。

把需要事前拦截的接口和拦截器一起放在一个视图模板里

comment = Blueprint('comment', name)

#评论操作前通过模块拦截器判断--用户是否登录

@comment.before_request

def before_comment():

#未登录情况下允许获取评论

if session.get('islogin') is None or session.get('islogin') != 'true':

return '你还没有登录,不能发表评论'

return 'not-login'

相关推荐
我不是混子几秒前
Java中关于Integer的使用
后端
Raven10086几秒前
DataWhale共学-向量数据库task01
后端
expect7g2 分钟前
Flink KeySelector
大数据·后端·flink
知了一笑6 分钟前
独立做产品,做一个,还是做多个找爆款?
前端·后端·产品
码事漫谈6 分钟前
深入剖析C++内存模型:超越原子性的多线程编程基石
后端
影灵衣丶8 分钟前
Go 1.25 实战解读:绿茶 GC 与容器核心数感知(工程影响与落地)
后端·go
码事漫谈9 分钟前
深入理解C++的Const关键字:从语法到语义的全面剖析
后端
SimonKing11 分钟前
一键开启!Spring Boot 的这些「魔法开关」@Enable*,你用对了吗?
java·后端·程序员
沢田纲吉15 分钟前
🗄️ MySQL 表操作全面指南
数据库·后端·mysql
小图图19 分钟前
Claude Code 黑箱揭秘
前端·后端