Flask開發之視圖
前言:主要介紹Flask的視圖裏面的參數配置、request、upload、abort、response、正則url、jsonify、cookie、session、鉤子、script等。
1.Hello World!
打開pycharm新建一個flask項目,如果你想省事可以參考一下截圖,新建項目:
找到app.py點擊鼠標右鍵運行:
運行成功:
訪問這個地址即可!
2.Flask參數配置
from flask import Flask, current_app
app = Flask(__name__,
static_url_path="/python", # 訪問靜態資源的url前綴, 默認值是static
static_folder="static", # 靜態文件的目錄,默認就是static
template_folder="templates", # 模板文件的目錄,默認是templates
)
#使用對象配置參數
class Config(object):
DEBUG = True
FLY = "fly"
app.config.from_object(Config)
@app.route("/")
def index():
# 讀取配置參數
# 1. 直接從全局對象app的config字典中取值
# print(app.config.get("ITCAST"))
# 2. 通過current_app獲取參數
print(current_app.config.get("FLY"))
return "hello flask"
if __name__ == '__main__':
# 啓動flask程序
app.run(host="0.0.0.0", port=5000, debug=True)
3.request數據請求
from flask import Flask, request
import json
app = Flask(__name__)
@app.route("/index", methods=["GET", "POST"])
def index():
"""獲取表單數據"""
name = request.form.get("name")
age = request.form.get("age")
return {'ret':0,'msg':name+age}
@app.route("/index2", methods=["GET", "POST"])
def index2():
"""獲取json數據"""
str_json = request.data
return {'ret':0,'msg':json.loads(str_json)}
@app.route("/index", methods=["GET", "POST"])
def index():
"""獲取args數據"""
city = request.args.get("city")
return {'ret':0,'msg':city}
if __name__ == '__main__':
app.run(debug=True)
測試代碼
import requests,pprint
def post():
data = {
'name': 'fly2',
'age': 18
}
# response = requests.post('http://127.0.0.1:5000/index1',data=data)
json = {
'city':'beijing',
'weather':'-15'
}
# response = requests.post('http://127.0.0.1:5000/index2',json=json)
args = {
'city':'beijing'
}
response = requests.post('http://127.0.0.1:5000/index3', params=args)
pprint.pprint(response.json())
if __name__ == '__main__':
post()
4.upload上傳文件
from flask import Flask, request
app = Flask(__name__)
@app.route("/upload", methods=["POST"])
def upload():
"""接受前端傳送過來的文件"""
file_obj = request.files.get("pic")
if file_obj is None:
# 表示沒有發送文件
return "未上傳文件"
# 直接使用上傳的文件對象保存
file_obj.save("./demo1.png")
return "上傳成功"
if __name__ == '__main__':
app.run(debug=True)
5.abort函數
如果在視圖函數執行過程中,出現了異常錯誤,我們可以使用abort函數立即終止視圖函數的執行。
from flask import Flask, request, abort, Response
app = Flask(__name__)
@app.route("/login", methods=["POST"])
def login():
"""獲取表單數據"""
name = request.form.get("name")
pwd = request.form.get("pwd")
if name != "zhangsan" or pwd != "admin":
# 使用abort函數可以立即終止視圖函數的執行
# 並可以返回給前端特定的信息
# 1 傳遞狀態碼信息, 必須是標準的http狀態碼
abort(404)
# # 2. 傳遞響應體信息
# resp = Response("login failed")
# abort(resp)
return "login success"
# 定義錯誤處理的方法
@app.errorhandler(404)
def handle_404_error(err):
"""自定義的處理錯誤方法"""
return "出現了404錯誤, 錯誤信息:%s" % err
if __name__ == '__main__':
app.run(debug=True)
6.response相應
from flask import Flask, request, abort, Response, make_response
app = Flask(__name__)
@app.route("/index")
def index():
# 1 使用元祖,返回自定義的響應信息
# 響應體 狀態碼 響應頭
# return "index page", 400, [("Fly", "pyton"), ("City", "shenzhen")]
# return "index page", 400, {"Fly": "python1", "City1": "sz1"}
# 2 使用make_response 來構造響應信息
resp = make_response("index page 2")
resp.status = "999 itcast" # 設置狀態碼
resp.headers["city"] = "sz" # 設置響應頭
return resp
if __name__ == '__main__':
app.run(debug=True)
7.正則URL示例
from flask import Flask
from werkzeug.routing import BaseConverter
class Regex_url(BaseConverter):
def __init__(self,url_map,*args):
super(Regex_url,self).__init__(url_map)
self.regex = args[0]
app = Flask(__name__)
app.url_map.converters['re'] = Regex_url
@app.route('/user/<re("[a-z]{3}"):id>')
def hello_itcast(id):
return 'hello %s' %id
8.使用jsonify返回json數據
from flask import Flask, jsonify
app = Flask(__name__)
@app.route("/index")
def index():
return jsonify(city="sz", country="china")
if __name__ == '__main__':
app.run(debug=True)
9.客戶端cookie
from flask import Flask, make_response, request
app = Flask(__name__)
@app.route("/set_cookie")
def set_cookie():
resp = make_response("success")
# 設置cookie, 默認有效期是臨時cookie,瀏覽器關閉就失效
resp.set_cookie("Fly", "Python")
resp.set_cookie("Fly1", "Python1")
# max_age設置有效期,單位:秒
resp.set_cookie("Fly2", "Python1", max_age=3600)
resp.headers["Set-Cookie"] = "Fly3=Python3; Expires=Sat, 18-Nov-2017 04:36:04 GMT; Max-Age=3600; Path=/"
return resp
@app.route("/get_cookie")
def get_cookie():
c = request.cookies.get("Fly")
return c
@app.route("/delete_cookie")
def delete_cookie():
resp = make_response("del success")
# 刪除cookie
resp.delete_cookie("Fly")
return resp
if __name__ == '__main__':
app.run(debug=True)
10.服務器端session
from flask import Flask, session, current_app
app = Flask(__name__)
# flask的session需要用到的祕鑰字符串
app.config["SECRET_KEY"] = "dhsodfhisfhosdhf29fy989"
@app.route("/login")
def login():
# 設置session數據
session["name"] = "python"
session["mobile"] = "18611111111"
return "login success"
@app.route("/index")
def index():
# 獲取session數據
name = session.get("name")
return "hello %s" % name
if __name__ == '__main__':
app.run(debug=True)
11.請求鉤子
在客戶端和服務器交互的過程中,有些準備工作或掃尾工作需要處理,比如:在請求開始時,建立數據庫連接;在請求結束時,指定數據的交互格式。爲了讓每個視圖函數避免編寫重複功能的代碼,Flask提供了通用設施的功能,即請求鉤子。
- before_first_request:在處理第一個請求前運行。
- before_request:在每次請求前運行。
- after_request:如果沒有未處理的異常拋出,在每次請求後運行。
- teardown_request:在每次請求後運行,即使有未處理的異常拋出。
from flask import Flask, request, url_for
app = Flask(__name__)
@app.route("/index")
def index():
print("index 被執行")
return "index page"
@app.route("/hello")
def hello():
print("hello 被執行")
return "hello page"
@app.before_first_request
def handle_before_first_request():
"""在第一次請求處理之前先被執行"""
print("handle_before_first_request 被執行")
@app.before_request
def handle_before_request():
"""在每次請求之前都被執行"""
print("handle_before_request 被執行")
@app.after_request
def handle_after_request(response):
"""在每次請求(視圖函數處理)之後都被執行, 前提是視圖函數沒有出現異常"""
print("handle_after_request 被執行")
return response
@app.teardown_request
def handle_teardown_request(response):
"""在每次請求 (視圖函數處理)之後都被執行, 無論視圖函數是否出現異常,都被執行, 工作在非調試模式時 debug=False"""
print("handle_teardown_request 被執行")
return response
if __name__ == '__main__':
app.run()
12.Flask-Script擴展命令行
通過使用Flask-Script擴展,我們可以在Flask服務器啓動的時候,通過命令行的方式傳入參數。
from flask import Flask
from flask_script import Manager # 啓動命令的管理類
app = Flask(__name__)
# 創建Manager管理類的對象
manager = Manager(app)
@app.route("/index")
def index():
return "index page"
if __name__ == '__main__':
# app.run(debug=True)
# 通過管理對象來啓動flask
manager.run()
結束!!!