Flask中的路由
endpoint 別名不能重復,對應的視圖函數,默認是視圖函數名。endpoint 才是路由的核心。視圖函數與路由的對應關系。可以通過url_for 反向創建url
# 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()