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

flask+python快速搭建

app.py

"""APP 入口模块"""
from traceback import format_excfrom api_limiter import limiter
from flask import Flask, jsonify
import loggingfrom controller import api_sql_blueapp = Flask(__name__)
limiter.init_app(app)
app.register_blueprint(api_sql_blue)@app.errorhandler(Exception)
def handle_exception(e):"""处理所有异常"""logging.error(format_exc())# 返回 JSON 错误响应return jsonify(error=str(e)), 500if __name__ == '__main__':app.run(debug=True,threaded=True)

controller.py

from flask import Blueprint, make_responsefrom response_dic import ResDic
from api_limiter import limiter
from flask import jsonify, request
from functools import wraps
from jsonschema import validate, ValidationErrorfrom sql_service import sql_import_deal, sql_query_dealapi_sql_blue = Blueprint('sql', __name__)def validate_json_and_schema(schema):"""验证请求数据是否是JSON格式,以及是否符合schema"""def decorator(f):@wraps(f)def wrapper(*args, **kwargs):if request.is_json:data = request.get_json()try:validate(instance=data, schema=schema)except ValidationError as e_validation:return jsonify(ResDic.from_params(code="400", msg=str(e_validation))), 200return f(*args, **kwargs)else:return jsonify(ResDic.from_params(code="400", msg="请求数据不是JSON格式")), 200return wrapperreturn decoratordef header_required(func):@wraps(func)def decorated_function(*args, **kwargs):authorization_header = request.headers.get('Authorization')if not authorization_header:return jsonify(ResDic.from_params(code="401", msg="请求参数异常")), 200return func(*args, **kwargs)return decorated_function@api_sql_blue.route('/import', methods=['POST'])
@validate_json_and_schema({"type": "object","properties": {"sql_txt": {"type": "string"}},"required": ["sql_txt"],
})
@limiter.limit("5/second", override_defaults=False)  # 一秒5次
@header_required
def sql_import():req_json_data = request.get_json()req = req_json_data["sql_txt"]result = sql_import_deal(req)response_data = jsonify(ResDic.from_params(code="0", data=result))response = make_response(response_data)return response@api_sql_blue.route('/query', methods=['POST'])
@limiter.limit("5/second", override_defaults=False)  # 一秒5次
@header_required
@validate_json_and_schema({"type": "object","properties": {"question": {"type": "string"}},"required": ["question"],
})
def sql_query():req_json_data = request.get_json()req = req_json_data["question"]result = sql_query_deal(req)response_data = jsonify(ResDic.from_params(code="0", data=result))response = make_response(response_data)return response

api_limiter.py

from flask_limiter import Limiter
from flask_limiter.util import get_remote_addresslimiter = Limiter(key_func=get_remote_address,default_limits=["50000 per day", "3600 per hour"]
)

response_dic.py

class ResDic:def __init__(self, code, data, msg):self.code = codeself.data = dataself.msg = msg@classmethoddef from_params(cls, code="200", data="", msg=""):return {"code": code, "data": data,"msg": msg}

sql_service.py

def sql_import_deal(req:str):return "import"def sql_query_deal(req:str):return "query"

config_utils.py

from dotenv import load_dotenv
import osload_dotenv('.env')  # 先加载默认的 .env 文件APP_ENV = os.environ.get('APP_ENV', 'dev').lower()
load_dotenv(f'.env_{APP_ENV}', override=True)  # 再加载环境相关的,def get_config(key: str) -> str:return os.environ.get(key)

.env

OPENAI_API_KEY=""

requirements.txt

Flask==2.3.2
Flask-Limiter==3.3.1
gevent==22.10.2
gunicorn==20.1.0
jsonschema==4.18.0
jsonschema-specifications==2023.6.1
numpy==1.23.5
numexpr==2.8.4
openai==0.27.4
openapi-schema-pydantic==1.2.4
py-healthcheck==1.10.1
pydantic==1.10.7
pydub==0.25.1
faiss-cpu==1.7.4
typing-inspect==0.8.0
typing_extensions==4.5.0
tiktoken==0.4.0
beautifulsoup4==4.12.2
gradio==3.36.1
pytest==7.4.0
python-dotenv==1.0.0
pymysql==1.1.0
urllib3==1.25.11
http://www.lryc.cn/news/172386.html

相关文章:

  • 基于微信小程序的美术馆预约平台设计与实现(源码+lw+部署文档+讲解等)
  • ruoyi-vue-pro yudao 项目商城 mall 模块启用及相关SQL脚本
  • default 和 delete 与默认构造函数 的使用
  • 【开发篇】一、热部署
  • 点云从入门到精通技术详解100篇-定子装配过程中基于深度学习的易变形材料的点云分割(下)
  • 谷歌浏览器关闭自动更新功能
  • 电商业务--技术负责人 250K*15
  • MySQL只同步单个表或多个表,非全部同步!
  • 【论文基本功】【LaTeX】个人常用易忘LaTeX命令
  • JVM参数调优——G1收集器
  • Linux cp命令使用指南:详细教程及实际应用场景解析
  • 树结构数据在table中回显 treeselect disabled
  • BOA服务器移植
  • 洛谷刷题入门篇:顺序结构
  • LVS+Haproxy
  • Linux知识
  • Java基础(三)
  • [Firefox/快捷键] 禁用Ctrl-W快捷键
  • Git常用命令diff和mv
  • 【谢希尔 计算机网络】第3章 数据链路层
  • 《DevOps实践指南》- 读书笔记(九)
  • 数据库数据恢复-SQL SERVER数据库分区被格式化的数据恢复方案
  • ubuntu安装ffmpeg
  • CentOS上安装Docker
  • 三相PWM整流器有限集模型预测电流控制MATLAB仿真模型
  • 【JavaEE】多线程(三)
  • 9.25day5---Qt
  • wpf制作自定义控件,并触发外部路由事件
  • axios全局路由拦截的设置方法
  • XSS跨站脚本攻击