Python輕量級(jí)web框架bottle使用方法解析
Bottle是一個(gè)輕量級(jí)的Web框架,此框架只由一個(gè) bottle.py 文件構(gòu)成,不依賴任何第三方模塊。
#!/usr/bin/env python# -*- coding:utf-8 -*-from bottle import template, Bottleapp = Bottle()@app.route(’/say’)def index(): return 'Hello World' # return template(’<b>Hello {{name}}</b>!’, name='bottle')if __name__ == ’__main__’: app.run(server='tornado',host=’0.0.0.0’, port=8888)
1、路由系統(tǒng)
路由系統(tǒng)是的url對(duì)應(yīng)指定函數(shù),當(dāng)用戶請(qǐng)求某個(gè)url時(shí),就由指定函數(shù)處理當(dāng)前請(qǐng)求,對(duì)于Bottle的路由系統(tǒng)可以分為一下幾類:
靜態(tài)路由 動(dòng)態(tài)路由 請(qǐng)求方法路由 二級(jí)路由1.1靜態(tài)路由
@app.route('/login') # 默認(rèn)為get請(qǐng)求def hello(): return ''' <form action='/login' method='post'> Username:<input name='username' type='text' /> Password:<input name='password' type='password' /> <input value='Login' type='submit'/> </form> '''@app.route('/login',method='POST')def do_login(): username = request.forms.get('username') password = request.forms.get('password') print(username,password) if username and password: return '<p>login success</p>' else: return '<p>login failure</p>'
1.2動(dòng)態(tài)路由
@app.route(’/say/<name>’)def callback(name): return template(’<b>Hello {{name}}</b>!’) @app.route(’/say/<id:int>’)def callback(id): return template(’<b>Hello {{id}}</b>!’) @app.route(’/say/<name:re:[a-z]+>’)def callback(name): return template(’<b>Hello {{name}}</b>!’) @app.route(’/static/<path:path>’)def callback(path): return static_file(path, root=’static’)
1.3請(qǐng)求方法路由
@app.route(’/hello/’, method=’POST’) # 等同于@app.post(’/hello/’)def index(): ... @app.get(’/hello/’) # 等同于@app.route(’/hello/’,method=’GET’)def index(): ... @app.post(’/hello/’) # 等同于@app.route(’/hello/’,method=’POST’)def index(): ... @app.put(’/hello/’) # 等同于@app.route(’/hello/’,method=’PUT’)def index(): ... @app.delete(’/hello/’) def index(): ...
1.4二級(jí)路由
#!/usr/bin/env python# -*- coding:utf-8 -*-from bottle import template, Bottleapp01 = Bottle()@app01.route(’/hello/’, method=’GET’)def index(): return template(’<b>App01</b>!’)app01.py
#!/usr/bin/env python# -*- coding:utf-8 -*-from bottle import template, Bottleapp02 = Bottle()@app02.route(’/hello/’, method=’GET’)def index(): return template(’<b>App02</b>!’)app02.py
#!/usr/bin/env python# -*- coding:utf-8 -*-from bottle import template, Bottlefrom bottle import static_fileapp = Bottle() @app.route(’/hello/’)def index(): return template(’<b>Root {{name}}</b>!’, name='bottle') from root_dir import app01from root_dir import app02 app.mount(’app01’, app01.app01)app.mount(’app02’, app02.app02) app.run(host=’localhost’, port=8888)
1.5靜態(tài)文件映射,static_file()函數(shù)用于響應(yīng)靜態(tài)文件的請(qǐng)求
# 靜態(tài)文件映射,static_file()函數(shù)用于響應(yīng)靜態(tài)文件 的請(qǐng)求@app.route('/static/<filename:re:.*.jpg>')def send_image(filename): return static_file(filename, root=os.getcwd(), mimetype='image/jpg')@app.route('/static/<filename:path>') # 可匹配路徑def send_image(filename): return static_file(filename, root=os.getcwd(), mimetype='image/jpg')# 強(qiáng)制下載@app.route('/static/<filename:path>') # 可匹配路徑def download(filename): return static_file(filename, root=os.getcwd(), download=filename)
1.6使用error()函數(shù)自定義錯(cuò)誤頁(yè)面
@app.error(404)def error404(error):return '我找不到目標(biāo)了,我發(fā)生錯(cuò)誤了'
1.7HTTP錯(cuò)誤和重定向
abort()函數(shù)是生成HTTP錯(cuò)誤的頁(yè)面的一個(gè)捷徑
@app.route('/restricted')def restricted() abort(401,'Sorry, access denied')# 將url重定向到其他url,可以在location中設(shè)置新的url,接著返回一個(gè)303 # redirect()函數(shù)可以幫助我們做這件事@app.route('/wrong/url')def wrong() redirect('/right/url')
其他異常
除了HTTPResponse或者HTTPError以外的其他異常,都會(huì)導(dǎo)致500錯(cuò)誤,因此不會(huì)造成WSGI服務(wù)器崩潰
將bottle.app().catchall的值設(shè)為False來(lái)關(guān)閉這種行為,以便在中間件中處理異常
2.cookies
@app.route('/login', method='POST')def do_login(): username = request.forms.get('username') password = request.forms.get('password') print(username, password) if username and password: response.set_cookie('name',username, secret= ’some-secret-key’) # 設(shè)置cookie return '<p>login success</p>' else: return '<p>login failure</p>'@app.route('/static/<filename:re:.*.jpg>')def send_image(filename): username = request.get_cookie('name', secret= ’some-secret-key’) # 獲取cookie if username: return static_file(filename, root=os.getcwd(), mimetype='image/jpg') else: return 'verify failed'
bottle就的 set_cookie 的默認(rèn) path 是當(dāng)前路徑,也就是說(shuō),在這個(gè)頁(yè)面上存入的 cookie 在別的頁(yè)面通常是取不到的,不熟悉這點(diǎn)的人幾乎都要栽在這里。而且更坑的是:set_cookie 有 path 參數(shù)可以指定 path ,但 get_cookie 卻沒(méi)有這個(gè) path 參數(shù)可選——也就是說(shuō),你即使設(shè)置了其它 path ,如果 get_cookie 的時(shí)候不是剛好在那個(gè) path 下的話,也取不到……
解決方法:把所有的 cookie 都放到'/'下面,至少目前用下來(lái)感覺(jué)沒(méi)問(wèn)題。
注:request.query 或 request.forms 都是一個(gè) FormDict 類型,
其特點(diǎn)是:當(dāng)以屬性方式訪問(wèn)數(shù)據(jù)時(shí)——如 request.query.name,返回的結(jié)果是 unicode ,當(dāng)以字典試訪問(wèn)數(shù)據(jù)時(shí),如 :request.query[’name’]或者request.query.get('name'),則返回的結(jié)果是原編碼字符串
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. vue使用moment如何將時(shí)間戳轉(zhuǎn)為標(biāo)準(zhǔn)日期時(shí)間格式2. bootstrap select2 動(dòng)態(tài)從后臺(tái)Ajax動(dòng)態(tài)獲取數(shù)據(jù)的代碼3. js select支持手動(dòng)輸入功能實(shí)現(xiàn)代碼4. php redis setnx分布式鎖簡(jiǎn)單原理解析5. 《Java程序員修煉之道》作者Ben Evans:保守的設(shè)計(jì)思想是Java的最大優(yōu)勢(shì)6. CSS3中Transition屬性詳解以及示例分享7. Python數(shù)據(jù)相關(guān)系數(shù)矩陣和熱力圖輕松實(shí)現(xiàn)教程8. 如何在PHP中讀寫(xiě)文件9. java加載屬性配置properties文件的方法10. 什么是Python變量作用域
