Python輕量級web框架bottle使用方法解析

 更新時間:2020-06-14 04:45:11   作者:佚名   我要評論(0)

Bottle是一個輕量級的Web框架,此框架只由一個 bottle.py 文件構成,不依賴任何第三方模塊。


#!/usr/bin/env python
# -*- coding:utf-8 -*-
from bottle import

Bottle是一個輕量級的Web框架,此框架只由一個 bottle.py 文件構成,不依賴任何第三方模塊。

#!/usr/bin/env python
# -*- coding:utf-8 -*-
from bottle import template, Bottle

app = 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、路由系統

路由系統是的url對應指定函數,當用戶請求某個url時,就由指定函數處理當前請求,對于Bottle的路由系統可以分為一下幾類:

  • 靜態路由
  • 動態路由
  • 請求方法路由
  • 二級路由

1.1靜態路由

@app.route("/login") # 默認為get請求
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動態路由

@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請求方法路由

@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二級路由

#!/usr/bin/env python
# -*- coding:utf-8 -*-
from bottle import template, Bottle

app01 = 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, Bottle

app02 = 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, Bottle
from bottle import static_file
app = Bottle()
 
@app.route('/hello/')
def index():
  return template('<b>Root {{name}}</b>!', name="bottle")
 
from root_dir import app01
from root_dir import app02
 
app.mount('app01', app01.app01)
app.mount('app02', app02.app02)
 
app.run(host='localhost', port=8888)

1.5靜態文件映射,static_file()函數用于響應靜態文件的請求

# 靜態文件映射,static_file()函數用于響應靜態文件 的請求
@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")

# 強制下載
@app.route("/static/<filename:path>")  # 可匹配路徑
def download(filename):
  return static_file(filename, root=os.getcwd(), download=filename)

1.6使用error()函數自定義錯誤頁面

@app.error(404)
def error404(error):
return "我找不到目標了,我發生錯誤了"

1.7HTTP錯誤和重定向

abort()函數是生成HTTP錯誤的頁面的一個捷徑

@app.route("/restricted")
def restricted()
  abort(401,"Sorry, access denied")
# 將url重定向到其他url,可以在location中設置新的url,接著返回一個303 # redirect()函數可以幫助我們做這件事

@app.route("/wrong/url")
def wrong()
  redirect("/right/url")

其他異常

除了HTTPResponse或者HTTPError以外的其他異常,都會導致500錯誤,因此不會造成WSGI服務器崩潰

將bottle.app().catchall的值設為False來關閉這種行為,以便在中間件中處理異常

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')  # 設置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 的默認 path 是當前路徑,也就是說,在這個頁面上存入的 cookie 在別的頁面通常是取不到的,不熟悉這點的人幾乎都要栽在這里。而且更坑的是:set_cookie 有 path 參數可以指定 path ,但 get_cookie 卻沒有這個 path 參數可選——也就是說,你即使設置了其它 path ,如果 get_cookie 的時候不是剛好在那個 path 下的話,也取不到……

解決方法:把所有的 cookie 都放到"/"下面,至少目前用下來感覺沒問題。

注:request.query 或 request.forms 都是一個 FormDict 類型,

其特點是:當以屬性方式訪問數據時——如 request.query.name,返回的結果是 unicode ,當以字典試訪問數據時,如 :request.query['name']或者request.query.get("name"),則返回的結果是原編碼字符串

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:

  • python Django框架實現web端分頁呈現數據
  • python web框架Flask實現圖形驗證碼及驗證碼的動態刷新實例
  • python web框架中實現原生分頁
  • python web框架 django wsgi原理解析
  • Python Web框架之Django框架Model基礎詳解
  • Python Web框架之Django框架文件上傳功能詳解
  • python基于Selenium的web自動化框架
  • Python之Web框架Django項目搭建全過程

相關文章

  • Python輕量級web框架bottle使用方法解析

    Python輕量級web框架bottle使用方法解析

    Bottle是一個輕量級的Web框架,此框架只由一個 bottle.py 文件構成,不依賴任何第三方模塊。 #!/usr/bin/env python # -*- coding:utf-8 -*- from bottle import
    2020-06-14
  • Python xpath表達式如何實現數據處理

    Python xpath表達式如何實現數據處理

    xpath表達式 1. xpath語法 <bookstore> <book> <title lang="eng">Harry Potter</title> <price>999</price> </book> <book> <title lang="eng">Learning X
    2020-06-14
  • Python Django搭建網站流程圖解

    Python Django搭建網站流程圖解

    1. 創建Django REST framework工程 1.1手動創建工程文件夾 1.2進去工程文件夾內,執行命令:django-admin startproject web_project創建工程目錄 1.3修改,添加目錄
    2020-06-14
  • 簡單了解Spring Web相關模塊運行原理

    簡單了解Spring Web相關模塊運行原理

    Spring 的Web層中有4個模塊,分別為spring-web, spring-webmvc, spring-websocket 和 spring-webmvc-portlet。 spring-web spring-web 提供了核心的Web相關功能的
    2020-06-14
  • python如何更新包

    python如何更新包

    Python安裝新包,pip是很好用的安裝工具。 pip list 可以查詢所有已安裝的包和版本。怎么知道本地安裝包的版本是否有可以更新的新版本呢?通過pip list函數可以實現
    2020-06-14
  • numpy的Fancy Indexing和array比較詳解

    numpy的Fancy Indexing和array比較詳解

    一:Fancy Indexing import numpy as np #Fancy Indexing x = np.arange(16) np.random.shuffle(x) print(x) #打印所有的元素 print(x[2])#獲取某個元素
    2020-06-14
  • python屬于解釋語言嗎

    python屬于解釋語言嗎

    Python是一門解釋型語言? Python是一門解釋性語言,我就這樣一直相信下去,直到發現了*.pyc文件的存在。 如果是解釋型語言,那么生成的*.pyc文件是什么呢?c應該是
    2020-06-14
  • 使用sklearn對多分類的每個類別進行指標評價操作

    使用sklearn對多分類的每個類別進行指標評價操作

    今天晚上,筆者接到客戶的一個需要,那就是:對多分類結果的每個類別進行指標評價,也就是需要輸出每個類型的精確率(precision),召回率(recall)以及F1值(F1-s
    2020-06-14
  • python能開發游戲嗎

    python能開發游戲嗎

    python可以寫游戲,但不適合。下面我們來分析一下具體原因。 用錘子能造汽車嗎? 誰也沒法說不能吧?歷史上也確實曾經有些汽車,是用錘子造出來的。但一般來說,還是
    2020-06-14
  • python編寫softmax函數、交叉熵函數實例

    python編寫softmax函數、交叉熵函數實例

    python代碼如下: import numpy as np # Write a function that takes as input a list of numbers, and returns # the list of values given by the softmax
    2020-06-14

最新評論

买宝宝用品赚钱吗 股票配资风险优秀杨方配资平台 七乐彩综合走势图 股票融资余额 江西快三和值100走势图 快乐8平台是合法的吗 上海时时乐走势图单选表 海南环岛赛彩票直播 河北福彩排列五开奖结果查询 股票融资余额高意味着什么 河北快3二不同号推荐 澳洲快乐8基本走势图 浙江11选五技巧 极速赛车计划走势 股票分析报告怎么写范文 福彩3d字谜图谜总汇 秒速赛车大小单双计划