Flask中的路由、實例化參數和config配置文件

Flask中的路由

endpoint 別名不能重複,對應的視圖函數,默認是視圖函數名。endpoint 纔是路由的核心。視圖函數與路由的對應關係。能夠經過url_for 反向建立urlhtml

# methods容許的親求方式methods=["GET","POST","DELETE","PUT"]大小寫均可以;
# redirect_to永久重定向;
#strict_slashes是否嚴格要求路由匹配規則,就是url最後的/ strict_slashes=True時不能加/

@app.route('/look',endpoint="look",methods=["GET","POST"], redirect_to="/new_look",strict_slashes=True,defaults={」nid":1})
def look(nid):
    return f"123{nid}"   # 返回1231
# ********** 動態參數路由  **********
@app.route("/look/<int:page>")  # int只能接受int 類型的
@app.route("/look/<string:page>")   #string 能夠接收任意類型
@app.route("/look/<page>")  # 默認就是string類型
def look(page):
    return f"當前訪問第{page}頁"
@app.route("/look/<int:page>_<int:row>")
def look(page,row):
    return f"當前訪問第{page}頁"

應用場景  利用seng_file()
@app.route("/look/<folder>/<filename>")
def look(folder,filename):
    file_path = os.path.join(folder,filename)
    return send_file(file_path)
# 訪問:127.0.0.1:5000/look/image/1.jpg

@app.route("/look/<filename>")
def look(folder,filename):
    file_path = os.path.join("image",filename)
    return send_file(file_path)
# 訪問:127.0.0.1:5000/look/1.jpg

Flask 初始化 實例化參數

  • static_folder 靜態文件存放路徑
  • static_url_path 靜態文件訪問路徑 默認值爲「/{static_folder}」
  • template_folder 模板存放路徑
  • static_host 靜態文件訪問服務 http://127.0.0.1:5000/,也能夠是另外一臺服務器Host
from flask import Flask, render_template
# 若是html文件存放在了一個不是templates的文件夾中了,配置template_folder=是flask能夠找到html所在位置
# static_folder="statics" 靜態文件存放位置
# static_url_path='/static' 靜態文件訪問時的路徑
app = Flask(__name__, template_folder='templatesasdf', static_folder="statics", static_url_path='/static')
app.debug = True

@app.route('/')
def index():
    return render_template('index.html')

if __name__ == '__main__':
    app.run()
    

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Title</title>
</head>
<body>
<h1>h1h1</h1>
<img src="/static/1.jpg/">
</body>
</html>

Flask 對象配置文件

app.default_config()

{
    'DEBUG': False,  # 是否開啓Debug模式,開啓編輯時代碼重啓,LOG打印級別最低,錯誤信息透傳
    'TESTING': False,  # 是否開啓測試模式,無限接近生產環境,代碼編輯時不會重啓,LOG級別較高,錯誤信息再也不透傳
    
    'PROPAGATE_EXCEPTIONS': None,  # 異常傳播(是否在控制檯打印LOG) 當Debug或者testing開啓後,自動爲True
    'PRESERVE_CONTEXT_ON_EXCEPTION': None,  # 一兩句話說不清楚,通常不用它
    'SECRET_KEY': None,  # 以前遇到過,在啓用Session的時候,必定要有它
    'PERMANENT_SESSION_LIFETIME': timedelta(days=31),  # days , Session的生命週期(秒)默認31天的秒數
    'USE_X_SENDFILE': False,  # 是否棄用 x_sendfile
    'LOGGER_NAME': None,  # 日誌記錄器的名稱
    'LOGGER_HANDLER_POLICY': 'always',
    'SERVER_NAME': None,  # 服務訪問域名
    'APPLICATION_ROOT': None,  # 項目的完整路徑
    'SESSION_COOKIE_NAME': 'session',  # 在cookies中存放session加密字符串的名字
    'SESSION_COOKIE_DOMAIN': None,  # 在哪一個域名下會產生session記錄在cookies中
    'SESSION_COOKIE_PATH': None,  # cookies的路徑
    'SESSION_COOKIE_HTTPONLY': True,  # 控制 cookie 是否應被設置 httponly 的標誌,
    'SESSION_COOKIE_SECURE': False,  # 控制 cookie 是否應被設置安全標誌
    'SESSION_REFRESH_EACH_REQUEST': True,  # 這個標誌控制永久會話如何刷新
    'MAX_CONTENT_LENGTH': None,  # 若是設置爲字節數, Flask 會拒絕內容長度大於此值的請求進入,並返回一個 413 狀態碼
    'SEND_FILE_MAX_AGE_DEFAULT': 12,  # hours 默認緩存控制的最大期限
    'TRAP_BAD_REQUEST_ERRORS': False,
    # 若是這個值被設置爲 True ,Flask不會執行 HTTP 異常的錯誤處理,而是像對待其它異常同樣,
    # 經過異常棧讓它冒泡地拋出。這對於須要找出 HTTP 異常源頭的可怕調試情形是有用的。
    'TRAP_HTTP_EXCEPTIONS': False,
    # Werkzeug 處理請求中的特定數據的內部數據結構會拋出一樣也是「錯誤的請求」異常的特殊的 key errors 。
    # 一樣地,爲了保持一致,許多操做能夠顯式地拋出 BadRequest 異常。
    # 由於在調試中,你但願準確地找出異常的緣由,這個設置用於在這些情形下調試。
    # 若是這個值被設置爲 True ,你只會獲得常規的回溯。
    'EXPLAIN_TEMPLATE_LOADING': False,
    'PREFERRED_URL_SCHEME': 'http',  # 生成URL的時候若是沒有可用的 URL 模式話將使用這個值
    'JSON_AS_ASCII': True,
    # 默認狀況下 Flask 使用 ascii 編碼來序列化對象。若是這個值被設置爲 False ,
    # Flask不會將其編碼爲 ASCII,而且按原樣輸出,返回它的 unicode 字符串。
    # 好比 jsonfiy 會自動地採用 utf-8 來編碼它而後才進行傳輸。
    'JSON_SORT_KEYS': True,
    #默認狀況下 Flask 按照 JSON 對象的鍵的順序來序來序列化它。
    # 這樣作是爲了確保鍵的順序不會受到字典的哈希種子的影響,從而返回的值每次都是一致的,不會形成無用的額外 HTTP 緩存。
    # 你能夠經過修改這個配置的值來覆蓋默認的操做。但這是不被推薦的作法由於這個默認的行爲可能會給你在性能的代價上帶來改善。
    'JSONIFY_PRETTYPRINT_REGULAR': True,
    'JSONIFY_MIMETYPE': 'application/json',
    'TEMPLATES_AUTO_RELOAD': None,
}

app.config["SECRET_KEY"]="!@#$%^&*()"   # 效率高
app.secret_key = "!@#$%^&*()"   # 效率低
app.config['SESSION_COOKIE_NAME']: 'session'    # 配置session的名字,默認是session,第一個字符必定不能是空格,不然拿不到session值

config配置

# setting.py
class DedugConfig:
    DEBUG = True
    SECRET_KEY = "!@#$%^&*()"  # 效率高
    PERMANENT_SESSION_LIFETIME = 3600
    SESSION_COOKIE_NAME = 'I an session'
class TestConfig:
    TESTING = True
    SECRET_KEY = "!@#$%^&*()"  # 效率高
    PERMANENT_SESSION_LIFETIME = 3600
    SESSION_COOKIE_NAME = 'TestConfig'
from flask import Flask, render_template

app = Flask(__name__)
# app.config["debug"] = True
# app.config["PERMANENT_SESSION_LIFETIME"] = 3600  # session存活時間
# app.config["SECRET_KEY"] = "!@#$%^&*()"  # 效率高
# app.config['SESSION_COOKIE_NAME'] = 'session'
# app.default_config  # 查看配置文件

# 導入兩個debug配置類
from day02.setting import DebugConfig, TestConfig
# 能夠快速切換開發環境和測試環境
app.config.from_object(DebugConfig) # debug模式  開發環境
# app.config.from_object(TestConfig)    # testing模式 測試環境

@app.route('/')
def index():
    return render_template('index.html')

if __name__ == '__main__':
    app.run()
相關文章
相關標籤/搜索