Flask自定义装饰和g的使用

1. 在commons.py文件中新增一个装饰器类: 注:一定要加入@wraps进行装饰否则,装饰器在给多个函数进行装饰时会报错
python 复制代码
from functools import wraps
from flask import session, current_app, g



# 定义登陆装饰器,封装用户的登陆数据
def user_login_data(view_func):
    @wraps(view_func)
    def wrapper(*args, **kwargs):
        # 1,从sess1on中取出用户的user1d
        user_id = session.get("user_id")
        # 2通过user1d取出用户对象
        user = None
        if user_id:
            try:
                from info.models import User
                user = User.query.get(user_id)
            except Exception as e:
                current_app.logger.error(e)
        # 3.将u5er数据封装到g对象
        g.user = user
        return view_func(*args, **kwargs)

    return wrapper
2.装饰器的使用
python 复制代码
from flask import current_app, jsonify, render_template, abort, session, g
from . import news_blue
from info import models
from info.utils.response_code import RET
from ...utils.commons import user_login_data


@news_blue.route('/<int:news_id>')
##########自定义装饰器#######################
@user_login_data
def news_detail(news_id):
    try:
        ############################原本的这里的功能被装饰器取代了#############
        # # 0,从session中获取到user_id,并根据user_id获取到用户信息
        # user_id = session.get('user_id')
        # user = models.User.query.get(user_id)
        # 1,根据新闻编号,查询新闻对象
        try:
            news = models.News.query.get(news_id)
        except Exception as e:
            current_app.logger.error(e)
            return jsonify(errno=RET.DBERR, errmsg="获取新闻失败")
        # 2. 如果新闻对象不存在直接抛出异常
        if not news:
            abort(404)
        # 获取前6条热点新闻
        click_news = models.News.query.order_by(models.News.clicks.desc()).limit(6)
        click_news_list = []
        for item in click_news:
            click_news_list.append(item.to_dict())
        # 2.携带数据,渲染页面
        data = {
            "news_info": news.to_dict(),
        #########这里的user直接从g中取出,如果使用装饰包裹时g中是没有user的#########
            "user_info": g.user.to_dict() if g.user else '',
            "news": click_news_list
        }
    except Exception as e:
        current_app.logger.error(e)
        return jsonify(errno=RET.UNKOWNERR, errmsg='未知错误!')
    return render_template("news/detail.html", data=data)
相关推荐
2401_879693871 小时前
Python深度学习入门:TensorFlow 2.0/Keras实战
jvm·数据库·python
@PHARAOH1 小时前
HOW - Go 开发入门(一)
开发语言·后端·golang
xixihaha13247 小时前
将Python Web应用部署到服务器(Docker + Nginx)
jvm·数据库·python
xixihaha13247 小时前
Python游戏中的碰撞检测实现
jvm·数据库·python
Andya_net8 小时前
Spring | @EventListener事件机制深度解析
java·后端·spring
ID_180079054738 小时前
模拟1688商品详情的Python API实现,返回符合风格的JSON数据
开发语言·python·json
程序员小远8 小时前
软件测试之功能测试详解
自动化测试·软件测试·python·功能测试·测试工具·职场和发展·测试用例
无限大69 小时前
《AI观,观AI》:专栏总结+答疑|吃透核心,解决你用AI的所有困惑
前端·后端
我的xiaodoujiao9 小时前
API接口自动化测试详细图文教程学习系列1--序章
python·学习·pytest
ZhengEnCi9 小时前
P1B-Python环境配置基础完全指南-Windows系统安装与验证
python