flask基础(上篇)
目錄
一、flask入門與路由
二、flask路由
三、flask請求響應(yīng)異常
flask入門與路由
1. flask介紹
Flask是一個基于Python實現(xiàn)的web開發(fā)的'微'框架
中文文檔地址
Flask和Django一樣,也是一個基于MVC設(shè)計模式的Web框架
flask流行的主要原因:
a)有非常齊全的官方文檔,上手非常方便b) 有非常好的拓展機制和第三方的拓展環(huán)境,工作中常見的軟件都有對應(yīng)的拓展,自己動手實現(xiàn)拓展也很容易c) 微型框架的形式給了開發(fā)者更大的選擇空間2. 安裝flask
2.1虛擬環(huán)境搭建
virtualenv --no-site-packages falskenv激活windows下虛擬環(huán)境 cd Scripts activate2.2 安裝
pip install flask3. 基于flask的最小的應(yīng)用
創(chuàng)建hello.py文件
from flask import Flaskapp = Flask(__name__)@app.route('/') def gello_world():return 'Hello World'if __name__ == '__main__':app.run()運行:python hello.py
3.1 初始化
from flask import Flaskapp = Flask(__name__)Flask類構(gòu)造函數(shù)唯一需要的參數(shù)就是應(yīng)用程序的主模塊或包。對于大多數(shù)應(yīng)用程序,Python的__name__變量就是那個正確的、你需要傳遞的值。Flask使用這個參數(shù)來確定應(yīng)用程序的根目錄,這樣以后可以相對這個路徑來找到資源文件。
3.2 路由
@app.route('/')客戶端例如web瀏覽器發(fā)送 請求 給web服務(wù),進而將它們發(fā)送給Flask應(yīng)用程序?qū)嵗?yīng)用程序?qū)嵗枰缹τ诟鱾€URL請求需要運行哪些代碼,所以它給Python函數(shù)建立了一個URLs映射。這些在URL和函數(shù)之間建立聯(lián)系的操作被稱之為 路由 。
在Flask應(yīng)程序中定義路由的最便捷的方式是通過顯示定義在應(yīng)用程序?qū)嵗系腶pp.route裝飾器,注冊被裝飾的函數(shù)來作為一個 路由。
3.3 視圖函數(shù)
在上一個示例給應(yīng)用程序的根URL注冊gello_world()函數(shù)作為事件的處理程序。如果這個應(yīng)用程序被部署在服務(wù)器上并綁定了 www.example.com 域名,然后在你的瀏覽器地址欄中輸入 http://www.example.com 將觸發(fā)gello_world()來運行服務(wù)。客戶端接收到的這個函數(shù)的返回值被稱為 響應(yīng) 。如果客戶端是web瀏覽器,響應(yīng)則是顯示給用戶的文檔。
類似于gello_world()的函數(shù)被稱作 視圖函數(shù) 。
3.4 動態(tài)名稱組件路由
你的Facebook個人信息頁的URL是 http://www.facebook.com/ ,所以你的用戶名是它的一部分。Flask在路由裝飾器中使用特殊的語法支持這些類型的URLs。下面的示例定義了一個擁有動態(tài)名稱組件的路由:
@app.route('/hello/<name>')def gello_world(name):return 'Hello World %s' % name用尖括號括起來的部分是動態(tài)的部分,所以任何URLs匹配到靜態(tài)部分都將映射到這個路由。當(dāng)視圖函數(shù)被調(diào)用,Flask發(fā)送動態(tài)組件作為一個參數(shù)。在前面的示例的視圖函數(shù)中,這個參數(shù)是用于生成一個個性的問候作為響應(yīng)。
在路由中動態(tài)組件默認為字符串,但是可以定義為其他類型。例如,路由/user/只匹配有一個整數(shù)在id動態(tài)段的URLs。Flask路由支持int、float
如下:
@app.route('/hello/<int:id>')def gello_stu_id(id):return 'Hello World id: %s' % id3.5 服務(wù)啟動
if __name__ == '__main__':app.run()注意: __name__ == '__main__'在此處使用是用于確保web服務(wù)已經(jīng)啟動當(dāng)腳本被立即執(zhí)行。當(dāng)腳本被另一個腳本導(dǎo)入,它被看做父腳本將啟動不同的服務(wù),所以app.run()調(diào)用會被跳過。
一旦服務(wù)啟動,它將進入循環(huán)等待請求并為之服務(wù)。這個循環(huán)持續(xù)到應(yīng)用程序停止,例如通過按下Ctrl-C。
有幾個選項參數(shù)可以給app.run()配置web服務(wù)的操作模式。在開發(fā)期間,可以很方便的開啟debug模式,將激活 debugger 和 reloader 。這樣做是通過傳遞debug為True來實現(xiàn)的。
run()中參數(shù)有如下:
debug 是否開啟調(diào)試模式,開啟后修改python的代碼會自動重啟port 啟動指定服務(wù)器的端口號host主機,默認是127.0.0.14. 修改啟動方式,使用命令行參數(shù)啟動服務(wù)
4.1 安裝插件
pip install flask-script調(diào)整代碼
manager = Manager(app=‘自定義的flask對象’)
啟動的地方
manager.run()
4.2 啟動命令
python hellow.py runserver -h 地址 -p 端口 -d -r其中:-h表示地址。-p表示端口。-d表示debug模式。-r表示自動重啟
5. route規(guī)則
5.1 規(guī)則
寫法:
converter類型:
string 字符串 int 整形 float 浮點型 path 接受路徑,接收的時候是str,/也當(dāng)做字符串的一個字符 uuid 只接受uuid字符串 any 可以同時指定多種路徑,進行限定例子:
@app.route('/helloint/<int:id>/')@app.route('/getfloat/<float:price>/')@app.route('/getstr/<string:name>/',methods=['GET', 'POST'])@app.route('/getpath/<path:url_path>/')@app.route('/getbyuuid/<uuid:uu>/',methods=['GET', 'POST'])實現(xiàn)對應(yīng)的視圖函數(shù):
@blue.route('/hello/<name>/') def hello_man(name):print(type(name))return 'hello name:%s type:%s' % (name, type(name))@blue.route('/helloint/<int:id>/') def hello_int(id):print(id)print(type(id))return 'hello int: %s' % (id)@blue.route('/index/') def index():return render_template('hello.html')@blue.route('/getfloat/<float:price>/') def hello_float(price):return 'float: %s' % price@blue.route('/getstr/<string:name>/') def hello_name(name):return 'hello name: %s' % name@blue.route('/getpath/<path:url_path>/') def hello_path(url_path):return 'path: %s' % url_path@blue.route('/getuuid/') def gello_get_uuid():a = uuid.uuid4()return str(a)@blue.route('/getbyuuid/<uuid:uu>/') def hello_uuid(uu):return 'uu:%s' % uu5.2 methods請求方法
常用的請求類型有如下幾種
GET : 獲取 POST : 創(chuàng)建 PUT : 修改(全部屬性都修改) DELETE : 刪除 PATCH : 修改(修改部分屬性)定義url的請求類型:
@blue.route('/getrequest/', methods=['GET', 'POST'])flask藍圖
1. 什么是藍圖
在Flask項目中可以用Blueprint(藍圖)實現(xiàn)模塊化的應(yīng)用,使用藍圖可以讓應(yīng)用層次更清晰,開發(fā)者更容易去維護和開發(fā)項目。藍圖將作用于相同的URL前綴的請求地址,將具有相同前綴的請求都放在一個模塊中,這樣查找問題,一看路由就很快的可以找到對應(yīng)的視圖,并解決問題了。
2. 使用藍圖
2.1 安裝
pip install flask_blueprint2.2 實例化藍圖應(yīng)用
blue = Blueprint(‘first’,\_\_name\_\_)注意:Blueprint中傳入了兩個參數(shù),第一個是藍圖的名稱,第二個是藍圖所在的包或模塊,__name__代表當(dāng)前模塊名或者包名
2.3 注冊
app = Flask(\_\_name\_\_)app.register_blueprint(blue, url_prefix='/user')注意:第一個參數(shù)即我們定義初始化定義的藍圖對象,第二個參數(shù)url_prefix表示該藍圖下,所有的url請求必須以/user開始。這樣對一個模塊的url可以很好的進行統(tǒng)一管理
3 使用藍圖
修改視圖上的裝飾器,修改為@blue.router(‘/’)
@blue.route('/', methods=['GET', 'POST']) def hello():# 視圖函數(shù)return 'Hello World'注意:該方法對應(yīng)的url為127.0.0.1:5000/user/
4 url_for反向解析
后端中使用反向解析:
語法:
無參情況: url_for('藍圖中定義的第一個參數(shù).函數(shù)名') 有參情況: url_for('藍圖中定義的第一個參數(shù).函數(shù)名', 參數(shù)名=value)定義跳轉(zhuǎn):
from flask import url_for, redirect # 第一步: 生成藍圖對象 blueprint = Blueprint('first', __name__)@blueprint.route('/') def hello():return 'hello'@blueprint.route('/stu/<id>/') def stu(id):return 'hello stu: %s' % id# 1. 定義路由跳轉(zhuǎn)到hello方法 @blueprint.route('/redirect/') def my_redirect():# 第一種方法# redirect: 跳轉(zhuǎn)# url_for: 反向解析# 'first.hello': 藍圖第一個參數(shù).跳轉(zhuǎn)到的函數(shù)名return redirect(url_for('first.hello'))# 第二種方法return redirect('/hello/index/')# 2. 定義路由跳轉(zhuǎn)到stu方法 @blueprint.route('/redirect_id/') def stu_redirect():return redirect(url_for('first.stu', id=3))注意: 反向解析可以使用url_for方法,也可以直接定義跳轉(zhuǎn)的路由地址。
前端中使用反向解析
語法:
無參形式: {{ url_for('藍圖中定義的第一個參數(shù).函數(shù)名') }}有參形式: {{ url_for('藍圖中定義的第一個參數(shù).函數(shù)名',參數(shù)名=value) }}flask請求響應(yīng)異常
1. 請求request
服務(wù)端在接收到客戶端的請求后,會自動創(chuàng)建Request對象
由Flask框架創(chuàng)建,Requesy對象不可修改
屬性:
url:完整的請求地址base_url:去掉GET參數(shù)的urlhost_url:只有主機和端口號的urlpath:路由中的路徑method:請求方法remote_addr:請求的客戶端的地址args:GET請求參數(shù)form:POST請求參數(shù)files:文件上傳headers:請求頭cookies:請求中的cookie1.1 args-->GET請求參數(shù)包裝
a)args是get請求參數(shù)的包裝,args是一個ImmutableMultiDict對象,類字典結(jié)構(gòu)對象
b)數(shù)據(jù)存儲也是key-value
c) 獲取GET請求中傳遞的參數(shù),request.args
1.2 form-->POST請求參數(shù)包裝
a)form是post請求參數(shù)的包裝,args是一個ImmutableMultiDict對象,類字典結(jié)構(gòu)對象
b)數(shù)據(jù)存儲也是key-value
c) 獲取POST請求中傳遞的參數(shù),request.form
重點:ImmutableMultiDict是類似字典的數(shù)據(jù)結(jié)構(gòu),但是與字典的區(qū)別是,可以存在相同的鍵。
在ImmutableMultiDict中獲取數(shù)據(jù)的方式,dict['key']或者dict.get('key')或者dict.getlist('key')
2. 響應(yīng)Response
Response是由開發(fā)者自己創(chuàng)建的
創(chuàng)建方法:
from flask import make_responsemake_response創(chuàng)建一個響應(yīng),是一個真正的Response對象狀態(tài)碼:
格式:make_reponse(data,code),其中data是返回的數(shù)據(jù)內(nèi)容,code是狀態(tài)碼
a)直接將內(nèi)容當(dāng)做make_response的第一個參數(shù),第二個參數(shù)直接寫返回的狀態(tài)碼b)直接在render后加返回的狀態(tài)碼例子1:
定義一個獲取GET請求的request的方法,并將返回成功的請求的狀態(tài)碼修改為200
@blue.route('/getrequest/', methods=['GET']) def get_request():print(request)return '獲取request', 200例子2:
返回response響應(yīng),并添加返回結(jié)果的狀態(tài)碼200
@blue.route('/getresponse/') def get_response():response = make_response('<h2>我是響應(yīng)</h2>', 500)return response或者:
@blue.route('/getresponse/', methods=['GET']) def get_user_response():login_html = render_template('login.html')res = make_response(login_html, 200)return res3. 終止/異常捕獲
自動拋出異常:abort(狀態(tài)碼)
捕獲異常處理:errorhandler(狀態(tài)碼),定義的函數(shù)中要包含一個參數(shù),用于接收異常信息
3.1 定義終止程序
@blue.route('/make_abort/') def get_abort():abort(400)return '終止'3.2 捕獲定義的異常
@blue.errorhandler(400) def handler(exception):return '捕獲到異常信息:%s' % exception轉(zhuǎn)載于:https://www.cnblogs.com/zhangliang91/p/11109128.html
總結(jié)
以上是生活随笔為你收集整理的flask基础(上篇)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。