from flask import Flask from flask_sqlalchemy import SQLAlchemy from flask_login import LoginManager from configparser import ConfigParser # init SQLAlchemy so we can use it later in our models db = SQLAlchemy() def create_app(): conf = ConfigParser() conf.read("./config.ini") app = Flask(__name__) app.config['SECRET_KEY'] = conf['app']['SECRET_KEY'] app.config['SQLALCHEMY_DATABASE_URI'] = conf['app']['SQLALCHEMY_DATABASE_URI'] db.init_app(app) login_manager = LoginManager() login_manager.login_view = 'auth.login' login_manager.init_app(app) login_manager.login_message = "请先登录" from .models import User @login_manager.user_loader def load_user(user_id): # since the user_id is just the primary key of our user table, use it in the query for the user return User.query.get(int(user_id)) with app.app_context(): db.create_all() # blueprint for auth routes in our app from .auth import auth as auth_blueprint app.register_blueprint(auth_blueprint) # blueprint for non-auth parts of app from .main import main as main_blueprint app.register_blueprint(main_blueprint) return app