Bottle(Flask)样的tornado开发

起因:

今年春节后发现有个tornado web的东西,app server+web framework的集合体,正好工作
中有个项目需要其中的异步远程调用的特性,遂研究之,用到现在感触良多,其性能尚可,
但是作为Web Framework看来其封装方式我并不喜欢,窃以为不够紧凑,需要设置的地方不
够清晰,很多功能的使用稍显繁琐。并且在新创建一个app的时候如果不参看已有的app做为
参考,重头写起来很困难。
举个例子 :
代码
 1 
 2  import  tornado.httpserver
 3  import  tornado.ioloop
 4  import  tornado.options
 5  import  tornado.web
 6 
 7  from  tornado.options  import  define, options
 8 
 9  define( " port " , default = 8888 , help = " run on the given port " , type = int)
10 
11  class  MainHandler(tornado.web.RequestHandler):
12       def  get(self):
13          self.write( " Hello, world " )
14 
15  def  main():
16      tornado.options.parse_command_line()
17      application  =  tornado.web.Application([
18          (r " / " , MainHandler),
19      ])
20      http_server  =  tornado.httpserver.HTTPServer(application)
21      http_server.listen(options.port)
22      tornado.ioloop.IOLoop.instance().start()
23 
24  if   __name__   ==   " __main__ " :
25      main()
26 

 

 

从官网的例子就能看出,首先启动一个服务就很麻烦了,加之Python在开发的时候智能感知
能起的作用不是很大,所以开发起来相当的纠结。而且其中我最需要的远程页面异步访问的
功能,就需要涉及到N个地方。
最近新出的Flask,Bottle等框架简洁的API让我很是眼热,但是如果在tornado后端用wsgi
来使用Bottle又没有办法使用异步远程访问,相当于阉割了一个我最需要的功能,所以怒由
心中起恶向胆边生,自起炉灶在tornado的Web Framework基础上实现了这个东西,由于是简
化了tornado的开发方式,所以就称之为 easytor 吧

从DEMO开始:

同样是实现一个HelloWorld的APP,我们用easytor来做做看:
easytor只有一个文件,你可以直接放在项目的目录中,或者安装后使用

1  from  easytor.app  import  apprun,route
2 
3  @route( " ^/hello/([^/]+)$ " )
4  def  hello(tor,name):
5       return  u " hello %s " % name
6 
7  if   __name__ == " __main__ " :
8      apprun()

 


我们import easytor.app模块中的 apprun和route,apprun是启动服务器的方法,而route
是一个Decorator,用来把一个handler函数和映射到的url一起注册到easytor的处理器列表
中。

url映射:

easytor中定义了很多Decorator,用于注册一些特定方法并挂载到相应的事件中。最重要的
就是route。
用route注册的函数至少有一个参数,第一个参数是tornado的handler对象,访问参数,
headers,cookie,是从这个参数开始,详细的内容参见tornado的文档。
url映射通过route这个Decorator来注册,同时route还可以通过参数指定访问这个url是否
需要认证,是否是Ajax请求和接受请求的方法。
route可以将正则表达式中的组取出来成为Handler函数的参数,如同Demo里那样,如果访问
/hello/alex,就显示 hello alex

输出Response:

easytor通过Handler函数的返回值向浏览器输出内容,返回值可以是str,unicode,或者几
个包装类,json,view,static_file,redirect,remote,async。实例化后将实例直接return 
即可。
比如要输出json,只需要

1  return  json(dict(name = " alex " ))

 


view用于包装render输出数据到模板。
redirect用于专跳页面。
remote是对远程异步获取页面的封装
async是一个空包装,用于挂起当前的请求(详见tornado的Demo:chat)

异步访问:

异步访问通过remote类来实现,看下面的例子:
1  @route( " ^/remoteacc$ " )
2  def  get_page(tor):
3       return  remote( " http://target.. " ,method = " GET " ,)
4 
5  def  on_get_page(tor,response):
6       return  response.body

 


对比tornado原本的例子,可以看到整个API简单了不少

目的:

少写代码,少写代码,还是少写代码

项目地址:http://bitbucket.org/alexander_lee/easytor
如果你也在用,或者打算用tornado来构建自己的Web应用,不妨试试easytor
同时也期待你的加入

PS:项目文档整理中,DEMO正在写,代码8号中午push上来

下一步目标:植入Session支持的扩展接口,加入fsdal代替tornado本身的数据访问模块 





你可能感兴趣的:(Bottle(Flask)样的tornado开发)