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"),则返回的结果是原编码字符串
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新动态
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]