Flask项目(一)前后端分离、项目目录结构、数据库设计、CRF

认识前后端分离

在这里插入图片描述

项目文件目录结构

单一文件中构建所有依赖工具

manage.py

# coding:utf-8

from flask import Flask
from flask_sqlalchemy import SQLAlchemy
from flask_session import Session
from flask_wtf import CSRFProtect

import redis


# 创建flask的应用对象
app = Flask(__name__)


class Config(object):
    """配置信息"""
    SECRET_KEY = "XHSOI*Y9dfs9cshd9"

    # 数据库
    SQLALCHEMY_DATABASE_URI = "mysql://root:mysql@127.0.0.1:3306/ihome_python04"
    SQLALCHEMY_TRACK_MODIFICATIONS = True

    # redis
    REDIS_HOST = "127.0.0.1"
    REDIS_PORT = 6379

    # flask-session配置
    SESSION_TYPE = "redis"
    SESSION_REDIS = redis.StrictRedis(host=REDIS_HOST, port=REDIS_PORT)
    SESSION_USE_SIGNER = True  # 对cookie中session_id进行隐藏处理
    PERMANENT_SESSION_LIFETIME = 86400 # session数据的有效期,单位秒


app.config.from_object(Config)

db = SQLAlchemy(app)


# 创建redis连接对象
redis_store = redis.StrictRedis(host=Config.REDIS_HOST, port=Config.REDIS_PORT)

# 利用flask-session,将session数据保存到redis中
Session(app)

# 为flask补充csrf防护
CSRFProtect(app)


@app.route("/index")
def index():
    return "index page"


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

创建工程目录(对单一文件进行拆分)

在这里插入图片描述
ihome\ _ init _.py

# coding:utf-8

from flask import Flask
from config import config_map
from flask_sqlalchemy import SQLAlchemy
from flask_session import Session
from flask_wtf import CSRFProtect

import redis
import logging
from logging.handlers import RotatingFileHandler


# 数据库
db = SQLAlchemy()

# 创建redis连接对象
redis_store = None

# 配置日志信息
# 创建日志记录器,指明日志保存的路径、每个日志文件的最大大小、保存的日志文件个数上限
file_log_handler = RotatingFileHandler("logs/log", maxBytes=1024*1024*100, backupCount=10)
# 创建日志记录的格式                 日志等级    输入日志信息的文件名 行数    日志信息
formatter = logging.Formatter('%(levelname)s %(filename)s:%(lineno)d %(message)s')
# 为刚创建的日志记录器设置日志记录格式
file_log_handler.setFormatter(formatter)
# 为全局的日志工具对象(flask app使用的)添加日记录器
logging.getLogger().addHandler(file_log_handler)
# 设置日志的记录等级
logging.basicConfig(level=logging.DEBUG)  # 调试debug级


# 工厂模式
def create_app(config_name):
    """
    创建flask的应用对象
    :param config_name: str  配置模式的模式的名字 ("develop",  "product")
    :return:
    """
    app = Flask(__name__)

    # 根据配置模式的名字获取配置参数的类
    config_class = config_map.get(config_name)
    app.config.from_object(config_class)

    # 使用app初始化db
    db.init_app(app)

    # 初始化redis工具
    global redis_store
    redis_store = redis.StrictRedis(host=config_class.REDIS_HOST, port=config_class.REDIS_PORT)

    # 利用flask-session,将session数据保存到redis中
    Session(app)

    # 为flask补充csrf防护
    CSRFProtect(app)

    # 注册蓝图
    from ihome import api_1_0
    app.register_blueprint(api_1_0.api, url_prefix="/api/v1.0"
Flask 中连接数据库的方式有很多种,可以使用 SQLALchemy、Peewee、MongoEngine、PyMySQL 等第三方库。以下是使用 SQLAlchemy 连接 MySQL 数据库的示例代码: 首先需要安装 SQLAlchemy 和 PyMySQL: ```python pip install sqlalchemy pip install pymysql ``` 然后在 Flask 中创建一个数据库连接对象: ```python from flask import Flask from flask_sqlalchemy import SQLAlchemy app = Flask(__name__) # 配置数据库连接地址 app.config['SQLALCHEMY_DATABASE_URI'] = 'mysql+pymysql://username:password@host:port/database_name' # 配置数据库连接池大小 app.config['SQLALCHEMY_POOL_SIZE'] = 10 # 关闭数据库对象修改跟踪 app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = False db = SQLAlchemy(app) ``` 其中,`SQLALCHEMY_DATABASE_URI` 是数据库连接地址,格式为:`mysql+pymysql://username:password@host:port/database_name`,具体含义如下: - `mysql+pymysql`:表示使用 PyMySQL 库连接 MySQL 数据库。 - `username`:数据库用户名。 - `password`:数据库密码。 - `host`:数据库主机地址。 - `port`:数据库连接端口,默认为 3306。 - `database_name`:数据库名称。 `SQLALCHEMY_POOL_SIZE` 是数据库连接池大小,可以根据需要进行调整。 `SQLALCHEMY_TRACK_MODIFICATIONS` 表示是否开启对象修改跟踪,建议关闭,避免出现性能问题。 接下来就可以使用 `db` 对象进行数据库操作了。例如,定义一个 User 模型类: ```python class User(db.Model): id = db.Column(db.Integer, primary_key=True) username = db.Column(db.String(50), unique=True) password = db.Column(db.String(50)) ``` 其中,`User` 继承自 `db.Model`,表示这是一个数据库模型类。`id`、`username`、`password` 分别是表中的字段名,`db.Column` 表示这是一个数据库字段。 如果需要创建表和字段,可以使用以下命令: ```python db.create_all() ``` 这样就可以在 Flask 中连接 MySQL 数据库了。当然,使用其他库连接其他类型的数据库也是类似的。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值