zoukankan      html  css  js  c++  java
  • tronado学习

    请求处理程序和请求参数:

    原创首发:http://www.cnblogs.com/zxlovenet/p/4128644.html

    程序将URL映射到tornado.web.RequestHandler的子类上去。
    # code 1
    class MainHandler(tornado.web.RequestHandler):
       def get(self):
           self.write("You requested the main page")
     
    class StoryHandler(tornado.web.RequestHandler):
       def get(self, story_id):
           self.write("You requested the story " + story_id)
     
    application = tornado.web.Application([
       (r"/", MainHandler),
       (r"/story/([0-9]+)", StoryHandler),
    ])
    
    get_argument() 方法获取查询字符串参数。
    self.request.files 可以访问上传文件。
    在继承类中通过 self.request.arguments.items() 方法获取所有返回对象。
     
    重写RequestHandler的方法函数:
    程序调用 initialize() 函数,这个函数的参数是 Application 配置中的关键字 参数定义。initialize 方法一般只是把传入的参数存 到成员变量中,而不会产生一些输出或者调用像 send_error 之类的方法。
    程序调用 prepare()。无论使用了哪种 HTTP 方法,prepare 都会被调用到,因此 这个方法通常会被定义在一个基类中,然后在子类中重用。prepare可以产生输出 信息。如果它调用了finish(或send_error` 等函数),那么整个处理流程 就此结束。
    程序调用某个 HTTP 方法:例如 get()、post()、put() 等。如果 URL 的正则表达式模式中有分组匹配,那么相关匹配会作为参数传入方法,见下图:
     
    见 code 1,RequestHandler中一些方法函数需要在其子类中重新定义。
    # handlerase.py
     
    get_current_user()    # 处理获得当前用户
     
    重定向:
    通过 self.redirect 或 RedirectHandler 。
    application = tornado.wsgi.WSGIApplication([
       (r"/([a-z]*)", ContentHandler),
       (r"/static/tornado-0.2.tar.gz", tornado.web.RedirectHandler,
        dict(url="http://github.com/downloads/facebook/tornado/tornado-0.2.tar.gz")),
    ], **settings)
    
     
    模板:
    模板支持 {% 控制语句 %}、{{ 表达式 }}
    可以通过 extends 和 block 实现模板继承。
     
     
    Cookie和Cookie安全:
    通过下面方式加强安全性
    class MainHandler(tornado.web.RequestHandler):
       def get(self):
           if not self.get_secure_cookie("mycookie"):
               self.set_secure_cookie("mycookie", "myvalue")
               self.write("Your cookie was not set yet!")
           else:
               self.write("Your cookie was set!")
     
    application = tornado.web.Application([
       (r"/", MainHandler),
    ], cookie_secret="61oETzKXQAGaYdkL5gEmGeJJFuYh7EQnp2XdTP1o/Vo=")
    
    另一种配置写法:
    class MainHandler(BaseHandler):
       @tornado.web.authenticated
       def get(self):
           name = tornado.escape.xhtml_escape(self.current_user)
           self.write("Hello, " + name)
     
    settings = {
       "cookie_secret": "61oETzKXQAGaYdkL5gEmGeJJFuYh7EQnp2XdTP1o/Vo=",
       "login_url": "/login",
    }
    application = tornado.web.Application([
       (r"/", MainHandler),
       (r"/login", LoginHandler),
    ], **settings)
    
    @tornado.web.authenticated    # 用于用户认证
    cookie_secret    # 用于加密cookie
    login_url    # 记录重定向地址
    xsrf_cookies    # 开关XSRF防范机制
     
    静态文件和主动式文件缓存:
    "static_path": os.path.join(os.path.dirname(__file__), "static")
    static_url() 函数会将相对地址转成一个类似于 /static/images/logo.png?v=aae54 的 URI,v 参数是 logo.png 文件的散列值, Tornado 服务器会把它发给浏览器,并以此为依据让浏览器对相关内容做永久缓存。
    由于 v 的值是基于文件的内容计算出来的,如果你更新了文件,或者重启了服务器 ,那么就会得到一个新的 v 值,这样浏览器就会请求服务器以获取新的文件内容。 如果文件的内容没有改变,浏览器就会一直使用本地缓存的文件,这样可以显著提高页 面的渲染速度。
     
    本地化:
     
    UI模块:
    class HomeHandler(tornado.web.RequestHandler):
       def get(self):
           entries = self.db.query("SELECT * FROM entries ORDER BY date DESC")
           self.render("home.html", entries=entries)
     
    class EntryHandler(tornado.web.RequestHandler):
       def get(self, entry_id):
           entry = self.db.get("SELECT * FROM entries WHERE id = %s", entry_id)
           if not entry: raise tornado.web.HTTPError(404)
           self.render("entry.html", entry=entry)
     
    settings = {
       "ui_modules": uimodules,
    }
    application = tornado.web.Application([
       (r"/", HomeHandler),
       (r"/entry/([0-9]+)", EntryHandler),
    ], **settings)
    {% module Entry(entry, show_comments=True) %}
    
    非阻塞式异步请求:
     Tornado 当中使用了 一种非阻塞式的 I/O 模型,所以你可以改变这种默认的处理行为——让一个请求一直保持 连接状态,而不是马上返回,直到一个主处理行为返回。要实现这种处理方式,只需要 使用 tornado.web.asynchronous 装饰器就可以了。
     
    调试模式和自动重载:
    如果你将 debug=True 传递给 Application 构造器,该 app 将以调试模式 运行。在调试模式下,模板将不会被缓存,而这个 app 会监视代码文件的修改, 如果发现修改动作,这个 app 就会被重新加载。在开发过程中,这会大大减少 手动重启服务的次数。然而有些问题(例如 import 时的语法错误)还是会让服务器 下线,目前的 debug 模式还无法避免这些情况。
     


  • 相关阅读:
    Codeforces Round #260 (Div. 2)
    面试题:给定数组a,找到最大的j-i, 使a[j]>a[i]
    ssh自动输入密码脚本 切换目录脚本
    make工作时的执行步骤
    Codeforces Round #259 (Div. 2)
    Codeforces Round #258 (Div. 2)
    如何在半径为1的圆中随机选取一个点
    面试中常问的有关随机选取k个数的总结
    topcoder SRM 628 DIV2 BracketExpressions
    topcoder SRM 628 DIV2 BishopMove
  • 原文地址:https://www.cnblogs.com/zxlovenet/p/4128644.html
Copyright © 2011-2022 走看看