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

flask: 保存异常时的错误信息和堆栈到日志

一,代码:

定义异常的处理

app.py

import os
from dotenv import load_dotenvfrom flask import Flask,jsonifyfrom flask_sqlalchemy import SQLAlchemy# 加载变量
dotenv_path = os.path.join(os.path.dirname(__file__), '.env')
load_dotenv(dotenv_path=dotenv_path, verbose=True, override=True)
db_uri = os.getenv("SQLALCHEMY_DATABASE_URI")
print("打印配置项:")
print(db_uri)app = Flask(__name__)# 数据库信息
host = '127.0.0.1'
port = '3306'
database = 'mybase'
username = 'root'
password = 'rootpassword'# 数据库类型+连接数据库的插件,这里使用的pymysql
DB_URI = f'mysql+pymysql://{username}:{password}@{host}:{port}/{database}'
# 配置数据库连接
app.config['SQLALCHEMY_DATABASE_URI'] = DB_URI
# 绑定Flask对象
db = SQLAlchemy()
db.init_app(app)from controller.admin import admin
from controller.user import userapp.register_blueprint(admin,url_prefix="/admin")
app.register_blueprint(user,url_prefix="/user")import logging
from logging.handlers import RotatingFileHandler
import traceback# 配置日志
file_handler = RotatingFileHandler("app_error.log")
file_handler.setLevel(logging.INFO)
file_handler.setFormatter(logging.Formatter('%(asctime)s %(levelname)s: %(message)s [in %(pathname)s:%(lineno)d]'))
app.logger.addHandler(file_handler)
app.logger.setLevel(logging.DEBUG)# 处理404找不到地址
@app.errorhandler(404)
def page_not_found(error):data = {"status": "failed","code": 500,"msg": "错误的路径"}return jsonify(data), 404# 处理异常 
@app.errorhandler(Exception)
def handle_exception(error):stack = traceback.format_exc()app.logger.error(f"An error occurred: {str(error)}")app.logger.error(stack)return failed_response(500,"An internal error occurred."), 500if __name__ == '__main__':app.run(debug=True)

 

触发异常 

# 用蓝图注册路由
@user.route("/add/")
def user_add():1 / 0  # 触发错误# 得到get参数name = request.values.get('name')age = request.args.get('age')# 返回data = {"status": "success","code": 200,"msg": "添加用户:"+name+",年龄:"+age}return jsonify(data)

 

二,测试效果:

控制台输出:

image

查看日志:

image

 

http://www.rkmt.cn/news/44082.html

相关文章:

  • git新建分支,以及推送本地代码到新建分支
  • 20251108——读后感4
  • 后缀学习笔记 | -er/-or -ee 系列 - 详解
  • 应用于ElasticSearch的C++ API——elasticlient - 教程
  • China Collegiate Programming Contest (CCPC) Jinan Site (The 3rd Universal Cup. Stage 17: Jinan) 题解
  • 2025年FFS重膜包装机厂家综合实力排行榜TOP5
  • 2025年国内重袋包装机厂家权威推荐榜单
  • 164. 最大间距
  • 2025大厂高频软件测试面试真题(附答案)
  • LiveBindings绑定到漂亮的TCombobox
  • 深入解析:眼控交互:ErgoLAB新一代人机交互方式
  • 2025年11月杭州集训记
  • Bash 入门指南-简介和常见命令
  • 最小多项式与线性递推
  • to kill a mocking bird
  • Linux 内核启动日志输出阶段分析
  • flask: 封装返回json的统一格式
  • 百度网盘把Windows下的习惯带进了Linux
  • 做题记录(Nov.)
  • 251108 会议整理
  • 阿里云智能集团首席科技官云栖大会要点总结
  • 自指自洽,天职天命,苦乐年华
  • 线段树(p1083)
  • 初识PPO
  • 现今除甲醛机构选哪家?深度分析
  • 轻松可视化信息的利器——JSON Crack
  • 详细介绍:C++微基础备战蓝桥杯string篇10.5
  • [ jupyter conda 环境]
  • 深入解析:仿mudou——Connection模块(连接管理)
  • 以太坊私有链搭建与智能合约部署指南 - 教程