摘要:初始化環境安裝插件創建文件,在使用的時候會載入文件初始化新建初始化文件使用工廠函數來創建以便后續寫的時候,能夠動態的傳入不同的配置,從而生成實例。
初始化 flask 環境
pip install pipenv mkdir flasky pipenv shell pipenv install flask # 安裝插件 pipenv install flask-sqlalchemy flask-migrate flask-wtf flask-mail pymysql mkdir app
創建 .env 文件,在使用pipenv的時候會載入.env 文件
# .env FLASK_APP=run.py FLASK_DEBUG = 1app初始化
新建初始化文件,使用工廠函數來創建 app 以便后續寫unittest的時候,能夠動態的傳入不同的配置,從而生成 app 實例。
# app/__init__.py from flask import Flask from config import config from flask_sqlalchemy import SQLAlchemy from flask_mail import Mail # 數據庫連接 db = SQLAlchemy() # 發送郵件 mail = Mail() def create_app(config_name): app = Flask(__name__) app.config.from_object(config[config_name]) # 初始化各種插件 config[config_name].init_app(app) db.init_app(app) mail.init_app(app) return app配置文件初始化
新建config.py
# config.py # coding: utf-8 import os class Config(object): SECRET_KEY = os.getenv("SECRET") MAIL_SERVER = os.getenv("MAIL_SERVER") MAIL_PORT = os.getenv("MAIL_PORT") MAIL_USE_TLS = os.getenv("MAIL_USE_TLS") MAIL_USERNAME = os.getenv("MAIL_USERNAME") MAIL_PASSWD = os.getenv("MAIL_PASSWD") SQLALCHEMY_TRACK_MODIFICATIONS = False def init_app(self): pass class DevConfig(Config): DEBUG = True SQLALCHEMY_DATABASE_URI = os.getenv("DEV_SQLALCHEMY_DATABASE_URI") or "mysql+pymysql://root:qwe123@127.0.0.1/flasky" class TestingConfig(Config): Testing = True SQLALCHEMY_DATABASE_URI = os.getenv("TEST_SQLALCHEMY_DATABASE_URI") or "mysql+pymysql://root:qwe123@127.0.0.1/flasky" class ProdConfig(Config): SQLALCHEMY_DATABASE_URI = os.getenv("SQLALCHEMY_DATABASE_URI") or "mysql+pymysql://root:qwe123@127.0.0.1/flasky" config = { "dev":DevConfig, "test":TestingConfig, "prod":ProdConfig, "default":DevConfig }
添加內容到 .env 文件
# .env ... SECRET_KEY = 81785a8c-1f9a-4cfb-bc9d-90a8374bbc15 MAIL_SERVER = xxx MAIL_PORT = xxx MAIL_USE_TLS = xx MAIL_USERNAME = tester MAIL_PASSWD = qwe123 DEV_SQLALCHEMY_DATABASE_URI= xxx TEST_SQLALCHEMY_DATABASE_URI=xxx SQLALCHEMY_DATABASE_URI = xxx初始化log
當應用運行起來的時候,最佳的做法不應該將錯誤信息直接輸出到頁面上讓用戶看到,這樣做既不專業,也不安全。最佳的做法是當應用發生錯誤的時候,應該直接將用戶導向 500 頁面,然后將發生的錯誤使用log記錄下來供開發進行調查。
# app/__init__.py from logging.handlers import SMTPHandler,RotatingFileHandler def create_app(config_name): ... if not app.debug: # 記錄到文件 if not os.path.exists("logs"): os.mkdir("logs") file_handler = RotatingFileHandler("logs/flasky.log",maxBytes=10240,backupCount=10) file_handler.setFormatter(logging.Formatter( "%(asctime)s %(levelname)s: %(message)s [in %(pathname)s:%(lineno)d]")) file_handler.setLevel(logging.INFO) app.logger.addHandler(file_handler) app.logger.info("app start.") # 發送郵件,可不設置 auth = None if app.config["MAIL_USERNAME"] or app.config["MAIL_PASSWD"]: auth = (app.config["MAIL_USERNAME"],app.config["MAIL_PASSWD"]) secure = None if app.config["MAIL_USE_SSL"]: secure = () mail_handler = SMTPHandler( mailhost=app.config["MAIL_SERVER"], fromaddr=app.config["MAIL_USERNAME"], toaddrs=app.config["ADMINS"], subject="flasky Error", credentials=auth,secure=secure) mail_handler.setLevel(logging.ERROR) app.logger.addHandler(mail_handler)藍圖 / 即插視圖
使用功能模塊來分割藍圖,使用即插視圖來分離路由和邏輯處理。方便代碼管理。
新建 index 文件夾,并添加 __init__.py 文件
# index/__init__.py from flask import Blueprint index_bp = Blueprint("index",__name__) from . import views,routes # index/views.py from flask.views import MethodView from flask import render_template class Index(MethodView): def get(self): return render_template("index.html") # index/routes.py from index import index_bp from index.views import Index index_bp.add_url_rule("/",view_func=Index.as_view("index")) # 當需要url_for 的時候,可以使用 index 這個名字 index.index # url_for("index.index") index 可以類比為就是這個函數的名字
以上完成了一個藍圖的基本設置。接下來添加藍圖到app實例
# app/__init__.py def create_app(config_name): ... from app.index import index_bp app.register_blueprint(index_bp) ... return app測試
測試初始化功能是否正常
pipenv shell flask run
打開 http://localhost:5000 查看是否存在錯誤
代碼地址:https://github.com/TheFifthMa...
參考推薦閱讀: 《OReilly.Flask.Web.Development.2nd.Edition》
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/43016.html
摘要:用意靈活的文件組織結構讓很多新手玩家痛苦萬分網上的相關教程也是良莠不齊本人也是在幾近崩潰的邊緣瘋狂試探堅持即時勝利終于被我摸索出一個較為適用的簡單文件組織結構本文從單文件結構逐步拆分成多個部分至于其中各個步驟拆分的用意還請恕在下才疏學淺難以 1用意 flask靈活的文件組織結構讓很多新手玩家痛苦萬分,網上的相關教程也是良莠不齊,本人也是在幾近崩潰的邊緣瘋狂試探,堅持即時勝利,終于被我摸...
摘要:目前,我們還沒有創建項目,進入預期項目目錄的上一級文件目錄下即可。使用腳手架初始化項目最后一個為項目名稱,可以自定義其它名稱。 本章以下命令都是在cmd命令行中進行的。 安裝命令行 npm i -g vue-cli 安裝完成后,輸入vue -V返回版本號,即安裝成功; 初始化項目 切換到項目目錄下 項目目錄,即項目所在目錄。 目前,我們還沒有創建項目,進入 預期項目目錄 的上一級文件目...
摘要:從使用和也是支持的。此處直接首頁其中當時,內的配置信息會直接覆蓋初始化后項目中的。文件接下來就是,這個文件負責的就是注入或是修改項目中文件。比如我的其中和就是用戶在處理中設定的問題的回答值。 vue-cli 之 Preset vue-cli 插件開發指南 TLDR 背景介紹 vue-cli 3 完全推翻了 vue-cli 2 的整體架構設計,所以當你需要給組里定制一份基于 vue-cl...
閱讀 2485·2021-11-24 09:39
閱讀 3527·2019-08-30 15:53
閱讀 601·2019-08-29 15:15
閱讀 2909·2019-08-26 13:23
閱讀 3224·2019-08-26 10:48
閱讀 650·2019-08-26 10:31
閱讀 776·2019-08-26 10:30
閱讀 2369·2019-08-23 18:32