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

flask项目框架搭建

目录结构

image-20241009161857636

blueprints

python包,蓝图文件,相当于路由组的概念,方便模块化开发

image-20241009162300635

例如auth.py文件

from flask import Blueprint, render_template

bp = Blueprint("auth", __name__, url_prefix="/auth")


@bp.route("/login")
def login():
    pass


@bp.route("/register")
def register():
    return render_template("register.html")

如果想访问register.html页面

那么请求url就是:ip:port/auth/register

app.py文件中需要进行初始化蓝图文件

from flask import Flask
from blueprints.qa import bp as qa_bp
from blueprints.auth import bp as auth_bp

app = Flask(__name__)

app.register_blueprint(qa_bp)
app.register_blueprint(auth_bp)



if __name__ == '__main__':
    app.run()

migrations

数据库迁移产生的包,其中包含迁移的脚本

由迁移三部曲生成:

第一

flask db init

第二(识别ORM模型的改变,生成迁移脚本)

flask db migrate

第三(运行迁移脚本,同步到数据库中)

flask db upgrade
static

存放静态文件的包,其中存放js,css,images等

templates

存放html文件

app.py

‌Flask的app.py文件是Flask框架中的核心应用程序类App的实现,包含了Flask应用程序的基本结构和核心功能。‌该文件定义了Flask应用程序的基本配置、路由注册、错误处理、请求响应处理以及扩展初始化等重要功能‌。

具体来说,app.py文件的作用包括以下几个方面:

‌配置管理‌:设置Flask应用程序的基本配置,如开启debug模式、设置密钥等‌。
‌路由注册‌:通过装饰器和类方法注册路由,定义应用程序的URL结构和处理函数‌。
‌错误处理‌:注册错误处理函数,定义当应用程序发生错误时的处理逻辑‌。
‌请求/响应处理‌:实现请求和响应的处理方法,包括路由函数、错误处理函数、视图方法等‌。
‌扩展初始化‌:初始化Flask扩展,如SQLAlchemy、Werkzeug、Jinja2等,以添加额外的功能和支持‌。

config.py

负责配置信息,例如数据库配置,邮件配置等

# 配置数据库信息
HOSTNAME = '127.0.0.1'
PORT = 3306
DATABASE = 'liu_oa'
USERNAME = 'root'
PASSWORD = 'xxxxxx'
DB_URI = f'mysql+pymysql://{USERNAME}:{PASSWORD}@{HOSTNAME}:{PORT}/{DATABASE}?charset=utf8mb4'
SQLALCHEMY_DATABASE_URI = DB_URI
exts.py

‌Flask中的exts.py文件主要用于解决第三方库的循环引用问题。‌ exts.py文件通过集中管理第三方库的导入,避免了在主程序和其他文件之间形成循环引用,从而简化了代码结构并提高了代码的可维护性‌。

具体来说,exts.py文件通常用于保存数据库和其他第三方库的初始化代码。由于数据库操作和其他第三方库的调用可能会在多个文件中进行,直接在这些文件中导入可能会导致循环引用的问题。通过将这部分代码集中放在exts.py文件中,可以有效地解决这个问题。

# 这个文件的目的是为了解决循环引用
from flask_sqlalchemy import SQLAlchemy
from flask_mail import Mail

db = SQLAlchemy()
mail = Mail()
models.py

负责模型的定义,和数据库表映射

from exts import db
from datetime import datetime


class UserModel(db.Model):
    __tablename__ = "user"
    id = db.Column(db.Integer, primary_key=True, autoincrement=True)
    username = db.Column(db.String(100), nullable=False)
    password = db.Column(db.String(100), nullable=False)
    email = db.Column(db.String(100), nullable=False, unique=True)
    join_time = db.Column(db.DateTime, default=datetime.now)
项目地址

https://gitee.com/yohoo-just-play/liu_oa/


http://www.kler.cn/news/340138.html

相关文章:

  • 【AI学习】Mamba学习(五):《HiPPO: Recurrent Memory with Optimal Polynomial Projections》
  • MES(Manufacturing Execution System,制造执行系统)核心模块
  • 滚雪球学MySQL[10.3讲]:MySQL社区资源与学习资料详解:官方文档、社区支持与工具推荐
  • 【GeekBand】C++设计模式笔记5_Observer_观察者模式
  • 深度学习Day-35:One-hot独热编码
  • nginx配置https加密
  • 5G NR相关笔记
  • Linux 命令 netstat 的 10 个基本用法
  • 以 AI 强化学习优化双边交易与借贷投资组合
  • 模拟算法基础C++
  • 计算机毕业设计 基于Python的新闻采集与订阅平台的设计与实现 Python+Django+Vue 前后端分离 附源码 讲解 文档
  • TM1618控制共阳极数码管的数据传送问题
  • everyday_question dq20240731
  • TCL Android面试题大全及参考答案
  • python 实现kahns algorithm卡恩算法
  • 人脸表情行为识别系统源码分享
  • 【网络安全】利用XSS、OAuth配置错误实现token窃取及账户接管 (ATO)
  • AMD股价分析:AMD股价能否再次反弹至200美元?以下是你该知道的!
  • 论文阅读笔记-How to Fine-Tune BERT for Text Classification?
  • 某大型钢铁集团公司高管竞聘上岗方案设计咨询项目