下面是官网中的一个Flask项目, 只须要简单的7行代码, 咱们就是能够让一个Flask项目运行起来。css
from flask import Flask app = Flask(__name__) @app.route('/') def hello_world(): return 'Hello World!' if __name__ == '__main__': app.run()
Flask因为框架体量小, 全部的拓展包都须要咱们本身去安装, 因此一个Flask项目会安装不少的拓展包是很常见的。基于项目的可拓展性和代码的可阅读性, 当代码量较大时, 将全部的代码写在一个文件中是一件很可怕的事, 因此咱们就要对其进行拆分, 主要仍是参考 MVC模式进行, 将不一样的功能放在其对应的模块中, 方便咱们进行阅读。html
建立app的文件目录, 将views 和 models 写入其中进行管理mysql
在app目录下建立 static 目录,存放静态文件web
在app目录下建立 templates 目录, 存放网页模板redis
在app目录下建立settings.py文件,存放全部的配置文件sql
from flask_script import Manager from myapp import create_app app = create_app('debug') manage = Manager(app = app) if __name__ == '__main__': manage.run()
static目录用来存放静态文件目录。如css,js,img等。templates目录用来存放html模板文件。数据库
from flask import Flask from myapp.ext import init_ext #导入扩展库中的函数 from myapp.settings import conf #从settings中导入配置文件 from myapp.views import init_blue #从views中导入注册蓝图的函数 from myapp.models import db #从models中导入实例化SQLAlchemy的对象 def create_app(env_name): #建立一个建立app的函数,并传入要配置的环境 if not env_name in conf.keys(): raise Exception('环境名称有问题') app = Flask(__name__) app.config.from_object(conf.get(env_name)) #根据传入的环境导入settings配置 init_ext(app) #实例化第三方插件 init_blue(app) #实例化蓝图 return app
from flask_session import Session from flask_sqlalchemy import SQLAlchemy def init_ext(app): #实例化第三方插件并绑定app se = Session() se.init_app(app) db = SQLAlchemy() db.init_app(app)
from flask_sqlalchemy import SQLAlchemy db = SQLAlchemy() #实例化SQLAlchemy对象 class Student(db.Model): id = db.Column(db.Integer,primary_key=True,autoincrement=True) name = db.Column(db.String(30),nullable=True,unique=True)
import os from redis import StrictRedis # 数据库的链接拼写规则 def get_db_uri(conf): uri = '{backend}+{engine}://{user}:{pwd}@{host}:{port}/{name}'.format( backend=conf.get('backend'), engine=conf.get('engine'), user=conf.get('user'), pwd=conf.get('pwd'), host=conf.get('host'), port=conf.get('port'), name=conf.get('name'), ) return uri class Config: Debug = False Test = False Online = False SECRET_KEY = 'aisofhas' #作session持久化的配置 SESSION_TYPE = 'redis' # 指定session存储方案 SESSION_KEY_PREFIX = 'myapp:' # 设置缓存的开头 SQLALCHEMY_TRACK_MODIFICATIONS = False class DebugConfig(Config): Debug = True SESSION_REDIS = StrictRedis('127.0.0.1',db=1) DATABASE = { 'backend':'mysql', 'engine':'pymysql', 'user':os.environ.get('DB_USER'), 'pwd':os.environ.get('DB_PASSWD'), 'host':'127.0.0.1', 'port':3306, 'name':'hzflask' } SQLALCHEMY_DATABASE_URI = get_db_uri(DATABASE) class TestConfig(Config): Test = True SESSION_REDIS = StrictRedis('127.0.0.1', db=2) DATABASE = { 'backend': 'mysql', 'engine': 'pymysql', 'user': os.environ.get('DB_USER'), 'pwd': os.environ.get('DB_PASSWD'), 'host': '127.0.0.1', 'port': 3306, 'name': 'hzflask2' } SQLALCHEMY_DATABASE_URI = get_db_uri(DATABASE) class OnlineConfig(Config): Online = True SESSION_REDIS = StrictRedis('127.0.0.1', db=3) DATABASE = { 'backend': 'mysql', 'engine': 'pymysql', 'user': os.environ.get('DB_USER'), 'pwd': os.environ.get('DB_PASSWD'), 'host': '127.0.0.1', 'port': 3306, 'name': 'hzflask3' } SQLALCHEMY_DATABASE_URI = get_db_uri(DATABASE) conf = { 'debug':DebugConfig, 'test':TestConfig, 'online':OnlineConfig, }
from flask import Blueprint, session, render_template from myapp.models import db, Student blue = Blueprint('wusir',__name__) def init_blue(app): app.register_blueprint(blue) @blue.route('/') def index(): return 'index'