基本映射

映射使用在根据不同URLs请求来产生相对应的返回内容.Bottle使用route() 修饰器来实现映射.

1

2

3

4

5

from bottle import route, run@route('/hello')def hello():

return "Hello World!"run() # This starts the HTTP server

运行这个程序,访问http://localhost:8080/hello将会在浏览器里看到 "Hello World!".

GET, POST, HEAD, ...

这个映射装饰器有可选的关键字method默认是method='GET'. 还有可能是POST,PUT,DELETE,HEAD或者监听其他的HTTP请求方法.

1

2

3

4

5

6

from bottle import route, request@route('/form/submit', method='POST')def form_submit():

form_data = request.POST

do_something(form_data)

return "Done"

动态映射

你可以提取URL的部分来建立动态变量名的映射.

1

2

3

@route('/hello/:name')def hello(name):

return "Hello %s!" % name

默认情况下, 一个:placeholder会一直匹配到下一个斜线.需要修改的话,可以把正则字符加入到#s之间:

1

2

3

@route('/get_object/:id#[0-9]+#')def get(id):

return "Object ID: %d" % int(id)

或者使用完整的正则匹配组来实现:

1

2

3

@route('/get_object/(?P[0-9]+)')def get(id):

return "Object ID: %d" % int(id)

正如你看到的,URL参数仍然是字符串, 即使你正则里面是数字.你必须显式的进行类型强制转换.

@validate() 装饰器

Bottle 提供一个方便的装饰器validate() 来校验多个参数.它可以通过关键字和过滤器来对每一个URL参数进行处理然后返回请求.

1

2

3

4

5

6

from bottle import route, validate# /test/validate/1/2.3/4,5,6,7@route('/test/validate/:i/:f/:csv')@validate(i=int, f=float, csv=lambda x: map(int, x.split(',')))def validate_test(i, f, csv):

return "Int: %d, Float:%f, List:%s" % (i, f, repr(csv))

你可能需要在校验参数失败时抛出ValueError.

返回文件流和JSON

WSGI规范不能处理文件对象或字符串.Bottle自动转换字符串类型为iter对象.下面的例子可以在Bottle下运行, 但是不能运行在纯WSGI环境下.

1

2

3

4

5

6

@route('/get_string')def get_string():

return "This is not a list of strings, but a single string"@route('/file')def get_file():

return open('some/file.txt','r')

字典类型也是允许的.会转换成json格式,自动返回Content-Type: application/json.

1

2

3

@route('/api/status')def api_status():

return {'status':'online', 'servertime':time.time()}

你可以关闭这个特性:bottle.default_app().autojson = False

Cookies

Bottle是把cookie存储在request.COOKIES变量中.新建cookie的方法是response.set_cookie(name, value[, **params]). 它可以接受额外的参数,属于SimpleCookie的有有效参数.

1

2

from bottle import responseresponse.set_cookie('key','value', path='/', domain='example.com', secure=True, expires=+500, ...)

设置max-age属性(它不是个有效的Python参数名) 你可以在实例中修改 cookie.SimpleCookie inresponse.COOKIES.

1

2

3

from bottle import responseresponse.COOKIES['key'] = 'value'response.COOKIES['key']['max-age'] = 500

模板

Bottle使用自带的小巧的模板.你可以使用调用template(template_name, **template_arguments)并返回结果.

1

2

3

@route('/hello/:name')def hello(name):

return template('hello_template', username=name)

这样就会加载hello_template.tpl,并提取URL:name到变量username,返回请求.

hello_template.tpl大致这样:

1

2

Hello {{username}}

How are you?

模板搜索路径

模板是根据bottle.TEMPLATE_PATH列表变量去搜索.默认路径包含['./%s.tpl', './views/%s.tpl'].

模板缓存

模板在编译后在内存中缓存.修改模板不会更新缓存,直到你清除缓存.调用bottle.TEMPLATES.clear().

模板语法

模板语法是围绕Python很薄的一层.主要目的就是确保正确的缩进块.下面是一些模板语法的列子:

%...Python代码开始.不必处理缩进问题.Bottle会为你做这些.

%end关闭一些语句%if ...,%for ...或者其他.关闭块是必须的.

{{...}}打印出Python语句的结果.

%include template_name optional_arguments包括其他模板.

每一行返回为文本.

Example:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

%header = 'Test Template'

%items = [1,2,3,'fly']

%include http_header title=header, use_js=['jquery.js', 'default.js']

{{header.title()}}

  • %for item in items:
  • %if isinstance(item, int):

    Zahl: {{item}}

    %else:

    %try:

    Other type: ({{type(item).__name__}}) {{repr(item)}}

    %except:

    Error: Item has no string representation.

    %end try-block (yes, you may add comments here)

    %end

%end

%include http_footer

Key/Value数据库

Bottle(>0.4.6)通过bottle.db模块变量提供一个key/value数据库.你可以使用key或者属性来来存取一个数据库对象.调用 bottle.db.bucket_name.key_name和bottle.db[bucket_name][key_name].

只要确保使用正确的名字就可以使用,而不管他们是否已经存在.

存储的对象类似dict字典, keys和values必须是字符串.不支持 items() and values()这些方法.找不到将会抛出KeyError.

持久化

对于请求,所有变化都是缓存在本地内存池中. 在请求结束时,自动保存已修改部分,以便下一次请求返回更新的值.数据存储在bottle.DB_PATH文件里.要确保文件能访问此文件.

Race conditions

一般来说不需要考虑锁问题,但是在多线程或者交叉环境里仍是个问题.你可以调用 bottle.db.save()或者botle.db.bucket_name.save()去刷新缓存,但是没有办法检测到其他环境对数据库的操作,直到调用bottle.db.save()或者离开当前请求.

Example

1

2

3

4

5

6

7

from bottle import route, db@route('/db/counter')def db_counter():

if 'hits' not in db.counter:

db.counter.hits = 0

db['counter']['hits'] += 1

return "Total hits: %d!" % db.counter.hits

使用WSGI和中间件

bottle.default_app()返回一个WSGI应用.如果喜欢WSGI中间件模块的话,你只需要声明bottle.run()去包装应用,而不是使用默认的.

1

2

3

4

from bottle import default_app, runapp = default_app()newapp = YourMiddleware(app)run(app=newapp)

默认default_app()工作

Bottle创建一个bottle.Bottle()对象和装饰器,调用bottle.run()运行. bottle.default_app()是默认.当然你可以创建自己的bottle.Bottle()实例.

1

2

3

4

5

6

from bottle import Bottle, runmybottle = Bottle()@mybottle.route('/')def index():

return 'default_app'run(app=mybottle)

发布

Bottle默认使用wsgiref.SimpleServer发布.这个默认单线程服务器是用来早期开发和测试,但是后期可能会成为性能瓶颈.

有三种方法可以去修改:

使用多线程的适配器

负载多个Bottle实例应用

或者两者

多线程服务器

最简单的方法是安装一个多线程和WSGI规范的HTTP服务器比如Paste, flup, cherrypy or fapws3并使用相应的适配器.

1

2

from bottle import PasteServer, FlupServer, FapwsServer, CherryPyServerbottle.run(server=PasteServer) # Example

如果缺少你喜欢的服务器和适配器,你可以手动修改HTTP服务器并设置bottle.default_app()来访问你的WSGI应用.

1

2

3

4

def run_custom_paste_server(self, host, port):

myapp = bottle.default_app()

from paste import httpserver

httpserver.serve(myapp, host=host, port=port)

多服务器进程

一个Python程序只能使用一次一个CPU,即使有更多的CPU.关键是要利用CPU资源来负载平衡多个独立的Python程序.

单实例Bottle应用,你可以通过不同的端口来启动(localhost:8080, 8081, 8082, ...).高性能负载作为反向代理和远期每一个随机瓶进程的新要求,平衡器的行为,传播所有可用的支持与服务器实例的负载.这样,您就可以使用所有的CPU核心,甚至分散在不同的物理服

python web框架 多线程_python 简单web框架: Bottle相关推荐

  1. python scrapy框架爬虫_Python Scrapy爬虫框架学习

    Scrapy 是用Python实现一个为爬取网站数据.提取结构性数据而编写的应用框架. 一.Scrapy框架简介 Scrapy是一个为了爬取网站数据,提取结构性数据而编写的应用框架. 可以应用在包括数 ...

  2. python网站框架下载_Python搭建网站框架

    1. 机器上安装python 在python官网下载python的2.7版本,然后一路next就可以安装了: 安装结束后,开启菜单会有python客户端,但是一般使用cmd命令行模式进行运行: 添加p ...

  3. python网站模板下载_Python 的 Web 应用程序模板 - Visual Studio | Microsoft Docs

    Python Web 应用程序项目模板Python web application project templates 01/28/2019 本文内容 Visual Studio 中的 Python ...

  4. python开发web教学视频_Python快速Web开发入门与实践视频课程

    Python快速Web开发入门与实践欢迎来到KK的<Python快速Web开发入门与实践>捧场!下面请允许我为这套课程做一点介绍. <Python快速Web开发入门与实践>是一 ...

  5. idea ssm框架 mysql_idea搭建简单ssm框架的最详细教程(新)

    为开发一个测试程序,特搭建一个简单的ssm框架,因为网上看到很多都是比较老旧的教程,很多包都不能用了,eclipes搭建并且其中还附带了很多的其他东西,所以特此记录一下mac中idea搭建过程. 另: ...

  6. python如何使用多线程_python多线程与线程

    进程与线程的概念 进程 考虑一个场景:浏览器,网易云音乐以及notepad++ 三个软件只能顺序执行是怎样一种场景呢?另外,假如有两个程序A和B,程序A在执行到一半的过程中,需要读取大量的数据输入(I ...

  7. python爬取图片实例_Python简单爬取图片实例

    都知道Python的语法很简单易上手,也很适合拿来作爬虫等等,这里就简单讲解一下爬虫入门--简单地爬取下载网站图片.html 效果 就像这样自动爬取下载图片到本地:python 代码: 其实很简单,咱 ...

  8. nodejs php web,nodejs实现的简单web服务器功能示例

    本文实例讲述了nodejs实现的简单web服务器功能.分享给大家供大家参考,具体如下: 前端js代码: $.ajax({ url:'http://192.168.0.114:3000',//服务器地址 ...

  9. python io密集 多线程_python多进程和多线程究竟谁更快(详解)

    python3.6 threading和multiprocessing 四核+三星250G-850-SSD 自从用多进程和多线程进行编程,一致没搞懂到底谁更快.网上很多都说python多进程更快,因为 ...

最新文章

  1. data (phantonjs onclick)exploring cleaning
  2. Qt Creator美化源代码
  3. snmp,mrtg安装和配置(2) mrtg安装
  4. Python os模块文件操作(二)
  5. Vivado工程路径太长导致不能生成bit文件
  6. vba控制matlab,Matlab加VBA在实验室内质量控制中的应用(南京)
  7. 永远不要在代码中使用“User”这个单词
  8. java从文件读入个人信息_Nacos 作为配置中心 读取Properties配置信息
  9. 工具分享:VISIO 2010版windows_64正版软件32位(附下载链接)
  10. shell教你如何批量解压缩——unzip命令
  11. java串口rxtx_Java串口操作RXTX
  12. GWT RPC 开发
  13. 几种x-ray产生的原理
  14. “仅三天可见” 的朋友圈有方法破解啦!
  15. 手机app抓包https请求信息,解决SSL Pinning验证
  16. jy-12-SPRINGMYBATIS02——云笔记02-刘苍松
  17. jk触发器改为四进制_锁存器、触发器、寄存器和缓冲器的区别
  18. 程序员们的那些神表情,有木有击中你^_^
  19. 【5G科普】只要9张图,看懂什么是5G
  20. 关于1Byte 1K 1M 1G(换算)

热门文章

  1. windows 10下的kiosk模式
  2. Android开发之自定义ImageView圆角图片的方法
  3. 我的世界java版记分板_我的世界计分板指令 如何使用计分板教程
  4. Swift调用第三方OC项目
  5. Linux之加密和安全
  6. PostgreSQL 10.1 手册_部分 I. 教程_第 2 章 SQL语言
  7. centos7上配置Samba服务器完成与windows的文件共享
  8. 核心技术靠化缘是要不来的——自己动手写ORM框架
  9. 基于mcp940反编译Minecraft源代码
  10. linux之LAMP架构搭建