说明:该篇博客是博主一字一码编写的,实属不易,请尊重原创,谢谢大家!
接着上一篇博客继续往下写 :https://blog.csdn.net/qq_41782425/article/details/85613780
目录
一丶创建项目
1 新建ihome_python项目文件夹
2 在Pycharm中打开此文件 ,并配置项目解释器(python2环境)
3 在工程目录下创建manage.py作为项目启动文件
- step1 实现flask中最基本的工作
# coding:utf-8
from flask import Flask
app = Flask(__name__)
@app.route('/index')
def index():
return "index page"
if __name__ == '__main__':
app.run()
- step2 配置mysql数据库用于存储用户数据
class Config(object):
"""配置信息"""
DEBUG = True
SECRET_KEY = "cdtaogang**CSDN@uhduqw82981h"
# 连接mysql数据库
SQLALCHEMY_DATABASE_URI = "mysql://root:mysql@127.0.0.1:3306/ihome_python"
SQLALCHEMY_TRACK_MODIFICATIONS = True
app.config.from_object(Config)
db = SQLAlchemy(app)
- step3 在本地mysql中创建ihome_python数据库
create database ihome_python charset=utf8;
- step4 配置redis数据库用于保存session信息以及缓存数据(因为flask框架默认将session数据存到cookie中),所以这里需要利用flask_session这个工具包帮助我们将flask存储的session数据交给我们管理,这样就可以将session数据存到redis数据库中了
class Config(object):
"""配置信息"""
DEBUG = True
SECRET_KEY = "cdtaogang**CSDN@uhduqw82981h"
# 连接mysql数据库
SQLALCHEMY_DATABASE_URI = "mysql://root:mysql@127.0.0.1:3306/ihome_python"
SQLALCHEMY_TRACK_MODIFICATIONS = True
# redis数据库配置
REDIS_HOST = "127.0.0.1"
REDIS_PORT = 6379
app.config.from_object(Config)
db = SQLAlchemy(app)
#创建redis数据库连接对象
redis_store = redis.StrictRedis(host=Config.REDIS_HOST, port=Config.REDIS_PORT)
- step5 配置flask_session用于我们操作session到redis数据库(说明在Config类中再次创建redis数据库连接,是因为在实际线上环境中,可能需要将session数据存到不同的服务器上)
# 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数据的有效期,单位秒
# 利用flask_session, 将session数据保存到redis中
Session(app)
- step6 开启csrf防护机制(导入flask_WTF中的CSRFProtect类)
# 为flask补充csrf防护
CSRFProtect(app)
二丶创建工程目录(拆分manage.py)
1 拆分配置文件
- step1 在项目根目录下创建一个config.py文件,将manage.py中的Config配置类放到该文件中
- step2 工程实现后,有两种运行环境,开发测试环境以及生成环境(线上环境),所以flask程序在运行时,就需要配置两个配置类,一个是用于开发环境,另一个用于生成环境
class DevelopmentConfig(Config):
"""开发环境配置信息"""
DEBUG = True
class ProductConfig(Config):
"""生成环境配置信息"""
pass
- step3 将app对象设计为工厂模式
- step4 在config.py中创建配置映射
#构建配置映射关系
config_map = {
"develop": DevelopmentConfig,
"product": ProductConfig
}
- step5 导入config中的config_map,通过调用create_app方法,创建app对象,将我们需要的配置环境通过传参的方式来决定是用开发环境还是生产环境,在create_app方法中就按照指明的环境进行配置即可
- step6 因最初创建的manage.py作为项目启动文件,所以我们在manage文件中只保留启动代码即可,需将其余代码抽离出去,保证manage文件中没有其他的代码,项目根目录下只需要保留启动文件manage以及config配置文件,即在项目根目录下创建一个ihome的python包,将create_app代码放到这个ihome包的init文件中即可,随后在ihome包下创建一个static目录用于存放静态文件,再创建一个models.py文件用于做数据库的迁移
- step7 在manage中创建并绑定app对象的代码,放到init中,会导致无法绑定create_app方法里面的app,所以使用SQLAlchemy对象db提供的init_app方法,在create_app方法里面对db进行初始化,这样就解决了
- step8 在models.py文件中导入数据库对象db
from ihome import db
- step9 将manage文件中创建的redis数据库连接对象放到init文件中,需要思考是否放在create_app方法中,因为最初在manage文件中创建的redis数据库连接需要从config文件中拿去host以及port配置,所以我们在全局声明redis_store变量为None,然后在方法中通过config_map获取的环境配置类config_class,说白了也就是config中的开发类DevelopmentConfig,直接拿去类中我们配置好的r连接redis数据库的port和host
- step10 对于Session(app)和CSRFProtect(app),不会用到这两个对象来进行进一步操作,只是刚开始使用这两个对象来初始化app,一个是为了我们将session数据存到redis数据库,另一个是为了开启CSRF防护机制,所以直接放到create_app类即可
# 利用flask_session, 将session数据保存到redis中
Session(app)
# 为flask补充csrf防护
CSRFProtect(app)
- step11 创建蓝图,用于管理不同版本的视图,在ihome核心目录下创建一个api_1_0python包,代表1.0版本的蓝图,在这个蓝图下就可以创建各种各样的视图了,在api_1_0蓝图下创建一个demo.py文件,将启动文件manage中的视图函数放到里面
@app.route('/index')
def index():
return "index page"
- step12 在api_1_0包下的init文件中创建蓝图
- step13 在flask项目应用文件init中注册蓝图 ,首先在init文件中通过绝对路径导入api_1_0包,再通过app应用对象中的register_blueprint方法,注册api_1_0包中的api蓝图名字,并定义url前缀地址为/api/v1.0表示1.0版本
# 注册蓝图
app.register_blueprint(api_1_0.api, url_prefix="/api/v1.0")
- step14 在创建工程时,可能会用到数据库models文件,那么就需要使用迁移插件,从flask_script中引入脚本命令管理对象,再从flask_migrate中导入迁移执行者Migrate,迁移命令解析人员Migratecommand
三丶以开发环境进行项目测试
- step1 在Pycharm终端中,执行python manage.py runserver 默认端口,运行项目
- step2 打开浏览器输入http://127.0.0.1:5000/api/v1.0/index,测试运行项目是否成功
在浏览器中成功渲染出index视图函数返回的字符串,如下图
- step3 回到Pycharm终端查看程序日志,请求方式和地址以及状态码都是完全正确,代表项目设计成功