摘要:初始化環(huán)境安裝插件創(chuàng)建文件,在使用的時候會載入文件初始化新建初始化文件使用工廠函數(shù)來創(chuàng)建以便后續(xù)寫的時候,能夠動態(tài)的傳入不同的配置,從而生成實例。
初始化 flask 環(huán)境
pip install pipenv mkdir flasky pipenv shell pipenv install flask # 安裝插件 pipenv install flask-sqlalchemy flask-migrate flask-wtf flask-mail pymysql mkdir app
創(chuàng)建 .env 文件,在使用pipenv的時候會載入.env 文件
# .env FLASK_APP=run.py FLASK_DEBUG = 1app初始化
新建初始化文件,使用工廠函數(shù)來創(chuàng)建 app 以便后續(xù)寫unittest的時候,能夠動態(tài)的傳入不同的配置,從而生成 app 實例。
# app/__init__.py from flask import Flask from config import config from flask_sqlalchemy import SQLAlchemy from flask_mail import Mail # 數(shù)據(jù)庫連接 db = SQLAlchemy() # 發(fā)送郵件 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:[email protected]/flasky" class TestingConfig(Config): Testing = True SQLALCHEMY_DATABASE_URI = os.getenv("TEST_SQLALCHEMY_DATABASE_URI") or "mysql+pymysql://root:[email protected]/flasky" class ProdConfig(Config): SQLALCHEMY_DATABASE_URI = os.getenv("SQLALCHEMY_DATABASE_URI") or "mysql+pymysql://root:[email protected]/flasky" config = { "dev":DevConfig, "test":TestingConfig, "prod":ProdConfig, "default":DevConfig }
添加內(nèi)容到 .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
當(dāng)應(yīng)用運行起來的時候,最佳的做法不應(yīng)該將錯誤信息直接輸出到頁面上讓用戶看到,這樣做既不專業(yè),也不安全。最佳的做法是當(dāng)應(yīng)用發(fā)生錯誤的時候,應(yīng)該直接將用戶導(dǎo)向 500 頁面,然后將發(fā)生的錯誤使用log記錄下來供開發(fā)進行調(diào)查。
# 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.") # 發(fā)送郵件,可不設(shè)置 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)藍(lán)圖 / 即插視圖
使用功能模塊來分割藍(lán)圖,使用即插視圖來分離路由和邏輯處理。方便代碼管理。
新建 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")) # 當(dāng)需要url_for 的時候,可以使用 index 這個名字 index.index # url_for("index.index") index 可以類比為就是這個函數(shù)的名字
以上完成了一個藍(lán)圖的基本設(shè)置。接下來添加藍(lán)圖到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》
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/43016.html
摘要:用意靈活的文件組織結(jié)構(gòu)讓很多新手玩家痛苦萬分網(wǎng)上的相關(guān)教程也是良莠不齊本人也是在幾近崩潰的邊緣瘋狂試探堅持即時勝利終于被我摸索出一個較為適用的簡單文件組織結(jié)構(gòu)本文從單文件結(jié)構(gòu)逐步拆分成多個部分至于其中各個步驟拆分的用意還請恕在下才疏學(xué)淺難以 1用意 flask靈活的文件組織結(jié)構(gòu)讓很多新手玩家痛苦萬分,網(wǎng)上的相關(guān)教程也是良莠不齊,本人也是在幾近崩潰的邊緣瘋狂試探,堅持即時勝利,終于被我摸...
摘要:目前,我們還沒有創(chuàng)建項目,進入預(yù)期項目目錄的上一級文件目錄下即可。使用腳手架初始化項目最后一個為項目名稱,可以自定義其它名稱。 本章以下命令都是在cmd命令行中進行的。 安裝命令行 npm i -g vue-cli 安裝完成后,輸入vue -V返回版本號,即安裝成功; 初始化項目 切換到項目目錄下 項目目錄,即項目所在目錄。 目前,我們還沒有創(chuàng)建項目,進入 預(yù)期項目目錄 的上一級文件目...
摘要:從使用和也是支持的。此處直接首頁其中當(dāng)時,內(nèi)的配置信息會直接覆蓋初始化后項目中的。文件接下來就是,這個文件負(fù)責(zé)的就是注入或是修改項目中文件。比如我的其中和就是用戶在處理中設(shè)定的問題的回答值。 vue-cli 之 Preset vue-cli 插件開發(fā)指南 TLDR 背景介紹 vue-cli 3 完全推翻了 vue-cli 2 的整體架構(gòu)設(shè)計,所以當(dāng)你需要給組里定制一份基于 vue-cl...
閱讀 2489·2021-11-24 09:39
閱讀 3531·2019-08-30 15:53
閱讀 606·2019-08-29 15:15
閱讀 2912·2019-08-26 13:23
閱讀 3227·2019-08-26 10:48
閱讀 653·2019-08-26 10:31
閱讀 779·2019-08-26 10:30
閱讀 2372·2019-08-23 18:32