python編程Flask框架簡單使用教程
基礎(chǔ)知識
使用框架的優(yōu)點
穩(wěn)定性和可擴展性強
可以降低開發(fā)難度,提高了開發(fā)效率
Flask誕生于2010年,是Armin ronacher用Python語言基于Werkzeug工具箱編寫的輕量級Web開發(fā)框架
Flask本身相當于一個內(nèi)核,其他幾乎所有的功能都要用到擴展(郵件擴展Flask-Mail,用戶認證Flask-Login,數(shù)據(jù)庫Flask-SQL_Alchemy),都需要用第三方的擴展來實現(xiàn)。
其WSGI工具箱采用Werkzeug(路由模塊),模塊引擎則使用Jinja2.這兩個也是Flask框架的核心
Flask常用擴展包
| Flask-SQLalchemy | 操作數(shù)據(jù)庫 |
|---|---|
| Flask-script | 插入腳本 |
| Flask-migrate | 管理遷移數(shù)據(jù)庫 |
| Flask-Session | Session存儲方式指定 |
| Flask-WTF | 表單 |
| Flask-Mail | 郵件 |
| Flask-Bable | 提供國際化和本地化支持,翻譯; |
| Flask-Login | 認證用戶狀態(tài); |
| Flask-OpenID | 認證; |
| Flask-RESTful | 開發(fā)REST API的工具; |
| Flask-Bootstrap | 集成前端Twitter Bootstrap框架 |
| Flask-Moment | 本地化日期和時間 |
| Flask-Admin | 簡單而可擴展的管理接口的框架 |
擴展列表:http://shouce.jb51.net/flask0.10/extensions.html
1.中文文檔(http://shouce.jb51.net/flask0.10/index.html)
2.英文文檔(http://flask.pocoo.org/docs/0.11/)
基本格式
from flask import Flask
app=Flask(__name__)
@app.route('/')
def a():
return 'aa'
app.run()
打開谷歌 網(wǎng)址為你的ip地址后加上:再加上默認的端口號5000 頁面展示為aa
app.run(host='0.0.0.0',port=80,debug=True)
host:設(shè)置為'0.0.0.0'時在同一個局域網(wǎng)別的電腦ip都能訪問,不設(shè)置這個參數(shù)時只有自己的ip能訪問
port:是默認端口號,為80時,網(wǎng)址后面不用加:你設(shè)置的端口號,
debug:在代碼中修改return的值后debug的值為True時,不用重新執(zhí)行程序,刷新網(wǎng)頁即可刷新內(nèi)容
拓展
from flask import Flask
app=Flask(__name__)
@app.route('/<orders_id>') #加個<> <>里寫的內(nèi)容為參數(shù)
def a(orders_id):
return '%s'%orders_id
app.run()
在谷歌里輸入你的ip后加上/你要寫的內(nèi)容 網(wǎng)頁展示內(nèi)容即為你要寫的內(nèi)容
如果限制只能是數(shù)字的話 <int:orders_id> <float:orders_id>
return
return 只能返回字符串 和render_template
如果要返回字典之類的 要轉(zhuǎn)成json類型
import json json.dumps()
from flask import Flask,jsonify
return {'a':'b'} #報錯
return str({'a':'b'}) #純文本形式,沒有數(shù)據(jù)類型,即沒有鍵值對
return json.dumps({'a':'v'}) #文本形式,但保留了鍵值對
return jsonify({'a':'v'}) #json類型 有鍵值對
app.conifg['JSON_AS_ASCII']=False #將返回的漢字不以ASCII形式返回
app.config.from_pyfile('settings.ini') # 可以新建settings.ini 在這里寫配置
重定向
from flask import Flask,redirect,url_for
app=Flask(__name__)
@app.route('/')
def a():
return 'a'
@app.route('/five')
def five():
return redirect(url_for('a')) #當你輸入網(wǎng)址為你的ip+/+five 時 這個網(wǎng)頁展示內(nèi)容其實就跳轉(zhuǎn)到a()方法里返回的內(nèi)容
#重定向到黑馬官網(wǎng)
@app.route('/demo5')
def demo5():
return redirect('http://www.itheima.com')
#重定向到自己寫的視圖函數(shù)
#可以直接填寫自己url路徑
#也可以使用url_for生成指定視圖函數(shù)所對應(yīng)的url
@app.route('/demo1')
def demo1():
return 'demo1'
#重定向
@app.route('/demo5')
def demo5():
return redirect(url_for('demo1'))
#重定向到帶有參數(shù)的視圖函數(shù)
#在 url_for 函數(shù)中傳入?yún)?shù)
# 路由傳遞參數(shù)
@app.route('/user/<int:user_id>')
def user_info(user_id):
return 'hello %d' % user_id
# 重定向
@app.route('/demo5')
def demo5():
# 使用 url_for 生成指定視圖函數(shù)所對應(yīng)的 url
return redirect(url_for('user_info', user_id=100))
取網(wǎng)址參數(shù)
from flask import Flask,request,jsonify
app=Flask(__name__)
@app.route('/<id>')
def a(id):
return '%s'%id
#當你輸入的網(wǎng)址為你的ip + / + 你要展現(xiàn)的內(nèi)容, 頁面內(nèi)容即為你要展現(xiàn)的內(nèi)容
@app.route('/')
def b():
name=request.args.get('name')
id=request.args.get('id')
return jsonify({'name':name,'id':id})
#當你輸入的網(wǎng)址為你的ip + /? +name=小明&id=7 展現(xiàn)的內(nèi)容即為{'name':小明,'id':7}
content-type
json類型: 'content-type':'application/json'
字符串類型:'content-type':'text/plain'
解析類型:'content-type':'text/html'
cookie\session
獲取cookie request.get.cookie('')
獲取session session.get('')
cookie:指某些網(wǎng)站為了辨別用戶身份、進行會話跟蹤而儲存在用戶本地的數(shù)據(jù)(通常經(jīng)過加密)
復(fù)數(shù)形式Cookies
cookie是由服務(wù)器生成,發(fā)送給客戶端瀏覽器,瀏覽器會將Cookie的Key/value保存,下次請求同一網(wǎng)站時就發(fā)送該cookie給服務(wù)器(前提是瀏覽器設(shè)置為啟用cookie)
cookie的Key/value可以由服務(wù)器端自己定義
Cookie是存儲在瀏覽器中的一段純文本信息,建議不要存儲敏感信息如密碼,因為電腦上的瀏覽器可能被其它人使用
Cookie基于域名安全,不同域名的Cookie是不能互相訪問的
如訪問itcast.cn時向瀏覽器中寫了Cookie信息,使用同一瀏覽器訪問baidu.com時,無法訪問到itcast.cn寫的Cookie信息
瀏覽器的同源策略
當瀏覽器請求某網(wǎng)站時,會將本網(wǎng)站下所有Cookie信息提交給服務(wù)器,所以在request中可以讀取Cookie信息
#設(shè)置cookie
from flask import Flask,Response
@app.route('/cookie')
def set_cookie():
resp=Response("this is to set cookie")
resp.set_cookie('username','itcast')
return resp
設(shè)置過期時間
@app.route('/cookie')
def set_cookie():
response=Response('hello world')
response.set_cookie('username','itheima',3600) #單位是秒
return response
獲取cookie
from flask import Flask,request
#獲取cookie
@app.route('/request')
def resp_cookie():
resp=request.cookies.get('username')
return resp
Session
對于敏感重要的信息,建議儲存在服務(wù)器端,在服務(wù)器端進行狀態(tài)保持的方案就是session
session依賴于cookie
session數(shù)據(jù)的獲取
session:請求上下文對象,用于處理http請求中的一些數(shù)據(jù)內(nèi)容
@app.route('/index1')
def index1():
session['username']='itcast'
return reddirect(url_for('index'))
@app.route('/')
def index():
return session.get('username')
記得設(shè)置secretz-key='itcast' 這個里面的值自己可以隨意設(shè)置
刪除session
session.pop('')
app.config['PERMANENT_SESSION_LIFETIME']=20 #設(shè)置session的時效
flask路由
指定路由地址
#指定訪問路徑為demo1
@app.route('/demo')
def demo1():
return 'demo1'
給路由傳參
有時我們需要將同一類URL映射到同一個視圖函數(shù)處理,比如:使用同一個視圖函數(shù)來顯示不同用戶的個人信息
#路由傳遞參數(shù)
@app.route('/user/<user_id>')
def user_info(user_id):
return 'hello %s'%user_id
輸入的網(wǎng)址后綴加的什么 在網(wǎng)頁展示的就是什么,下面那個函數(shù)括號里必須是上面的參數(shù)
路由傳遞的參數(shù)默認當作string處理,也可以指定參數(shù)的類型
#路由傳遞參數(shù)
@app.route('user/<int:user_id>')
def user_info(user_id):
return 'hello %d'%user_id
這里指定int,尖括號中的內(nèi)容是動態(tài)的。在此暫時可以理解為接受int類型的值,實際上int代表使用IntergeConverter去處理url傳入的參數(shù)
指定請求方式
在Flask中。定義一個路由,默認的請求方式為:
GET
OPTIONS(自帶)
HEAD (自帶)
如果像添加請求方式,
@app.route('/demo2',methods=['GET','POST'])
def demo2():
#直接從請求中取到請求方式并返回
return request.method
request屬性
request就是flask中代表當前請求的request對象,期中一個請求上下文變量
(理解成全局變量,在視圖函數(shù)中直接使用可以取到當前本次請求)
屬性 說明 類型
data 記錄請求的數(shù)據(jù),并轉(zhuǎn)換為字符串 *
form 記錄請求中的表單數(shù)據(jù) MultiDict
args 記錄請求中的查詢參數(shù) MultiDict
cookies 記錄請求中的cookie信息 Dict
headers 記錄請求中的報文頭 EnvironHeaders
method 記錄請求使用的HTTP方法 GET/POST
url 記錄請求的URL地址 string
files 記錄請求上傳的文件 *
Request.Form:獲取以POST方式提交的數(shù)據(jù)(接收Form提交來的數(shù)據(jù));
Request.QueryString:獲取地址欄參數(shù)(以GET方式提交的數(shù)據(jù))
Request:包含以上兩種方式(優(yōu)先獲取GET方式提交的數(shù)據(jù)),它會在QueryString、Form、ServerVariable中都搜尋一遍。
requests模塊發(fā)送請求有data、params兩種攜帶參數(shù)的方法。
params在get請求中使用,data在post請求中使用。params是往url后面添加參數(shù),data是指POST請求傳入的字典或?qū)ο?/p>
上下文
上下文:相當于一個容器,保存了Flask程序運行過程中的一些信息
Flask中有兩種上下文,請求上下文和應(yīng)用上下文
請求上下文(request context)
思考:在試圖函數(shù)中,如何取到當前請求的相關(guān)數(shù)據(jù)?比如:請求地址,請求方式,cookie等等
在flask中,可以直接在視圖函數(shù)中使用request這個對象進行獲取相關(guān)數(shù)據(jù),而request就是請求上下文的對象,保存了當前本次請求的相關(guān)數(shù)據(jù),請求上下文對象有:request,session
request:
封裝了HTTP請求的內(nèi)容,針對的是http請求。舉例:user=request.args.get('user'),獲取的是get請求的參數(shù)
session:
用來記錄請求會話中的信息,針對的是用戶信息,舉例:session['name']=user.id,可以記錄用戶信息,還可以通過session.get['name']獲取用戶信息
應(yīng)用上下文對象有:current_app , g
current_app
應(yīng)用程序上下文用于存儲應(yīng)用程序中的變量,可以通過current_app.name打印當前app的名稱,也可以在current_app中存儲一些變量,例如:
應(yīng)用的啟動腳本是哪個文件,啟動時指定了哪些參數(shù)
加載了哪些配置文件,導(dǎo)入了哪些配置
連了那個數(shù)據(jù)庫
有哪些public的工具類,常量
應(yīng)用跑在那個機器上,IP多少,內(nèi)存多大
current_app.name
current_app.text_value='value'
g變量
g作為flask程序全局的一個臨時變量,充當著中間媒介的作用,我們可以通過它傳遞一些數(shù)據(jù),g保存的是當前請求的全局變量,不同的請求會有不同的全局變量,通過不同的thread id區(qū)別
g.name='abc'
注意:不同的請求,會有不同的全局變量
兩者區(qū)別:
請求上下文:保存了客戶端和服務(wù)器交互的數(shù)據(jù)
應(yīng)用上下文:flask應(yīng)用程序運行過程中,保存的一些配置信息,比如程序名、數(shù)據(jù)庫連接、應(yīng)用信息等
上下文中的對象只能在指定上下文使用,超出范圍不能使用, 請求上下文和應(yīng)用上下文原理實現(xiàn):http://shouce.jb51.net/flask0.10/appcontext.html
注冊路由
@app.route('/')
def hello():
#會返回status code
#content-type 在http headers里
#content-type=text/html #默認值 當成html格式來解析
#將返回的結(jié)果封裝成一個Response對象
headers={
# 'content-type':'text/plain', #當成普通的字符串來解析
'content-type':'application/json' #返回json類型
}
# response=make_response('<html></html>',200) #301是重定向
# response.headers=headers
# return response
# return '<html></html>'
return '<html></html>',200,headers
# app.add_url_rule('/hello',view_func=hello) #也可以這樣來注冊路由的
以上就是python編程Flask框架簡單使用教程的詳細內(nèi)容,更多關(guān)于python教程Flask框架使用的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
解決python nohup linux 后臺運行輸出的問題
今天小編就為大家分享一篇解決python nohup linux 后臺運行輸出的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-05-05
Python編程中Python與GIL互斥鎖關(guān)系作用分析
GIL互斥鎖用來保護Python世界里的對象,防止同一時刻多個線程執(zhí)行Python字節(jié)碼,確保線程安全,但也導(dǎo)致Python線程無法利用多核CPU優(yōu)勢,本文來探討Python將來是否有可能去除GIL2021-09-09

