|
|
- import logging
- import os
-
- from flask import Flask
- from flask import Blueprint
- from flask import request
-
- from be.view import testconn
- from be.view import auth
- from be.view import seller
- from be.view import buyer
- from be.model.creatTB import createTable
- from be.model.buyer import tostop
-
- bp_shutdown = Blueprint("shutdown", __name__)
-
- def shutdown_server():
- func = request.environ.get("werkzeug.server.shutdown")
- if func is None:
- raise RuntimeError("Not running with the Werkzeug Server")
- func()
-
-
- @bp_shutdown.route("/shutdown", methods=["POST","GET"])
- def be_shutdown():
- # tostop() ## 不需要测试自动取消时删去此部分
- shutdown_server()
- return "Server shutting down..."
-
- def be_run():
- this_path = os.path.dirname(__file__)
- parent_path = os.path.dirname(this_path)
- log_file = os.path.join(parent_path, "app.log")
- createTable()
-
- logging.basicConfig(filename=log_file, level=logging.ERROR)
- handler = logging.StreamHandler()
- formatter = logging.Formatter(
- "%(asctime)s [%(threadName)-12.12s] [%(levelname)-5.5s] %(message)s"
- )
- handler.setFormatter(formatter)
- logging.getLogger().addHandler(handler)
-
- app = Flask(__name__)
-
- app.register_blueprint(bp_shutdown)
- app.register_blueprint(testconn.bp_testconn)
- app.register_blueprint(auth.bp_auth)
- app.register_blueprint(seller.bp_seller)
- app.register_blueprint(buyer.bp_buyer)
-
- app.run()
|