一 :RequestHandler

  一般我们继承tornado.web.RequestHandler

  1,RequestHandler.initialize()一般用于初始化,第三个字典参数传入

  

class ProfileHandler(RequestHandler):
def initialize(self, database):
self.database = database def get(self, username):
... app = Application([
(r'/user/(.*)', ProfileHandler, dict(database=database)),
])

  2,RequestHandler.prepare()

    调用 prepare()。无论使用了哪种 HTTP 方法, prepare 都会被调用到, 因此 这个方法通常会被定义在一个基类中, 然后在子类中重用。prepare可以产生输出 信息。如果它调用了finish(或send_error` 等函数), 那么整个处理流程 就此结束。

  3,RequestHandler.on_finish()

    重写结束的方法

  4,RequestHandler.get

    RequestHandler.head

    RequestHandler.post

    RequestHandler.delete

    RequestHandler.path

    RequestHandler.put

    RequestHandler.options

  5,相当于指定,同时也可以增加需要写的函数

    

class WebDAVHandler(RequestHandler):
SUPPORTED_METHODS = RequestHandler.SUPPORTED_METHODS + ('PROPFIND',) def propfind(self):
pass

二:RequestHandler  取出请求结果的方式

    1,RequestHandler.get_argument

    2,RequestHandler.get_arguments

    3,RequeatHandler.get_query_argument

    4,RequestHandler.get_query_arguments

    5,RequestHandler.get_body_argument

    6,RequestHandler.get_body_arguments

    7,RequestHandler.decode_argument

    8,RequestHandler.request

    9,RequestHandler.path_args

    10,RequestHandler.path_kwargs

三 RequestHandler  设置值方式

    1,RequestHandler.set_status(status_codereason=None)

    2,RequestHandler.set_header(namevalue)

    3,RequestHandler.add_header(namevalue)

    4,RequestHandler.clear_header(name)

    5,RequestHandler.set_default_headers()[

    6,RequestHandler.write(chunk)

    7,RequestHandler.flush(include_footers=Falsecallback=None)(缓冲数据等)

    8,RequestHandler.finish(chunk=None)

    9,RequestHandler.render(template_name**kwargs)

    10,RequestHandler.render_string(template_name**kwargs)

    11,RequestHandler.get_template_namespace()

    12,RequestHandler.redirect(urlpermanent=Falsestatus=None)

    13,RequestHandler.send_error(status_code=500**kwargs)

    14,RequestHandler.write_error(status_code**kwargs

    15,RequestHandler.clear()

    16,RequestHandler.data_received(chunk)

四:Cookies

    1,RequestHandler.cookies

    2,RequestHandler.get_cookie(namedefault=None)

    3,RequestHandler.set_cookie(namevaluedomain=Noneexpires=Nonepath='/'expires_days=None,**kwargs)

    4,RequestHandler.clear_cookie(namepath='/'domain=None)

    5,RequestHandler.clear_all_cookies(path='/'domain=None)

    6,RequestHandler.get_secure_cookie(namevalue=Nonemax_age_days=31min_version=None)加密cookies

    7,RequestHandler.get_secure_cookie_key_version(namevalue=None)

    8,RequestHandler.set_secure_cookie(namevalueexpires_days=30version=None**kwargs)

    9,tornado.web.MIN_SUPPORTED_SIGNED_VALUE_VERSION= 1

    10,tornado.web.MAX_SUPPORTED_SIGNED_VALUE_VERSION= 2

    11,tornado.web.DEFAULT_SIGNED_VALUE_VERSION= 2

    12,tornado.web.DEFAULT_SIGNED_VALUE_MIN_VERSION= 1

五:其他

    

当前通过认证的用户在请求处理器的 self.current_user 当中, 而且还存在于模版中的current_user. 默认情况下, current_user 的值为 None.

为了在你的应用程序中实现用户认证, 你需要覆盖请求控制器中的 get_current_user() 方法 来确认怎样获取当前登陆的用户, 例如, 从 cookie 的值中获取该信息. 下面这个例子展示了通过用户的昵称来确定用户身份, 值被保存在 cookies 中:

class BaseHandler(tornado.web.RequestHandler):
def get_current_user(self):
return self.get_secure_cookie("user") class MainHandler(BaseHandler):
def get(self):
if not self.current_user:
self.redirect("/login")
return
name = tornado.escape.xhtml_escape(self.current_user)
self.write("Hello, " + name) class LoginHandler(BaseHandler):
def get(self):
self.write('<html><body><form action="/login" method="post">'
'Name: <input type="text" name="name">'
'<input type="submit" value="Sign in">'
'</form></body></html>') def post(self):
self.set_secure_cookie("user", self.get_argument("name"))
self.redirect("/") application = tornado.web.Application([
(r"/", MainHandler),
(r"/login", LoginHandler),
], cookie_secret="__TODO:_GENERATE_YOUR_OWN_RANDOM_VALUE_HERE__")

    1,RequestHandler.current_user()用于检查用户登录

def get_current_user(self):
user_cookie = self.get_secure_cookie("user")
if user_cookie:
return json.loads(user_cookie)
return None

      如果用prepare()初始化必须是gen.coroutine,,,结束yeile才可以以

    

@gen.coroutine
def prepare(self):
user_id_cookie = self.get_secure_cookie("user_id")
if user_id_cookie:
self.current_user = yield load_user(user_id_cookie)

六:装饰器

    1,tornado.web.asynchronous(method)

      一般适用于http开头的请求方式

      

class MyRequestHandler(RequestHandler):
@asynchronous
def get(self):
http = httpclient.AsyncHTTPClient()
http.fetch("http://friendfeed.com/", self._on_download) def _on_download(self, response):
self.write("Downloaded!")
self.finish()

    2,tornado.web.authenticated(method)

      用于判断是否登录状态

    3,classtornado.web.FallbackHandler(applicationrequest**kwargs)

      

wsgi_app = tornado.wsgi.WSGIContainer(
django.core.handlers.wsgi.WSGIHandler())
application = tornado.web.Application([
(r"/foo", FooHandler),
(r".*", FallbackHandler, dict(fallback=wsgi_app),
])

下面列出RequestHandler中需要重写的方法

RequestHandler.initialize()
RequestHandler.prepare()
RequestHandler.get()
RequestHandler.post()
RequestHandler.put()
RequestHandler.delete()
RequestHandler.option()
RequestHandler.patch()
RequestHandler.head()
RequestHandler.on_finish()
RequestHandler.set_default_headers()
RequestHandler.get_template_namespace()
RequestHandler.create_template_loader()
RequestHandler.write_error(status_code, **kwargs)
RequestHandler.get_user_locale()
RequestHandler.get_current_user()
RequestHandler.get_login_url()
RequestHandler.get_template_path()
RequestHandler.compute_etag()
RequestHandler.data_received()
RequestHandler.log_exception()

更过可以参考:http://tornado-zh-cn.readthedocs.io/zh_CN/latest/web.html#tornado.web.RequestHandler

tornado requesthandler可以重写的方法的更多相关文章

  1. Tornado 自定义Form,session实现方法

    一. 自定义Tornado 验证模块 我们知道,平时在登陆某个网站或软件时,网站对于你输入的内容是有要求的,并且会对你输入的错误内容有提示,对于Django这种大而全的web框架,是提供了form表单 ...

  2. tornado自定义实现django include方法

    tornado自定义实现django  include方法 自定义URLmethod模块 from Custom.errors import * def include(base_url, expan ...

  3. .NET 基础 一步步 一幕幕[面向对象之方法、方法的重载、方法的重写、方法的递归]

    方法.方法的重载.方法的重写.方法的递归 方法: 将一堆代码进行重用的一种机制. 语法: [访问修饰符] 返回类型 <方法名>(参数列表){ 方法主体: } 返回值类型:如果不需要写返回值 ...

  4. EF里查看/修改实体的当前值、原始值和数据库值以及重写SaveChanges方法记录实体状态

    本文目录 查看实体当前.原始和数据库值:DbEntityEntry 查看实体的某个属性值:GetValue<TValue>方法 拷贝DbPropertyValues到实体:ToObject ...

  5. 【java开发】方法重写和方法重载概述

    类的继承   父类-子类 关键字 extends 新建一个父类 public class Person {     private String name;          private int ...

  6. android中使用startactivityforresult跳转Activity后需要重写onBackPressed()方法

    在android项目中经常会用startactivityforresult从一个Activity跳转到另一个Activity(这里指Activity_A和Activity_B),你可以从Activit ...

  7. 重写toString()方法来描述一个类

    package com.zch.test; /* toString方法以及重写toString方法 toString方法是一个自我描述方法 方法本身返回的是该对象的实现类的 类名 + @ + hash ...

  8. 重写ajax方法实现异步请求session过期时跳转登录页面

    jQuery(function($){ // 备份jquery的ajax方法 var _ajax=$.ajax; // 重写ajax方法, $.ajax=function(opt){ var _suc ...

  9. 为什么重写equals时必须重写hashCode方法?

    原文地址:http://www.cnblogs.com/shenliang123/archive/2012/04/16/2452206.html 首先我们先来看下String类的源码:可以发现Stri ...

随机推荐

  1. python-sqlite3之占位符

    The sqlite3 module supports two kinds of placeholders: question marks (qmark style) and named placeh ...

  2. c3p0 APPARENT DEADLOCK!!! Creating emergency threads for unassigned pending tasks

    2018-01-04 15:02:03,319 ---com.mchange.v2.async.ThreadPoolAsynchronousRunner: com.mchange.v2.async.T ...

  3. 1.2 Activity

    Activity是个应用组件,它给用户提供了为了完成某些工作而可以进行交互操作的界面,例如,电话详情,打电 话,发邮件,或是浏览地图.每一个Activity都有一个窗口来绘制自已的用户界面.通常来说, ...

  4. love2d教程34--thread模块

    love的thread是一个单独的lua运行环境,与主线程平行.因此可以用线程来处理 处理复杂的计算,不过由于隔离,线程不能访问主线程的变量和方法,而且进程 间通信也受限.   可以在线程里共享lov ...

  5. flask 中xx.init_app(app)方法

    bootstrap = Bootstrap() mail = Mail() moment = Moment() db = SQLAlchemy() def create_app(config_name ...

  6. jquery.js:8672 Synchronous XMLHttpRequest on the main thread is deprecated because of its detrimental effects to the end user's experience. For more help, check https://xhr.spec.whatwg.org/.

    html5谷歌流浪器报错:jquery.js:8672 Synchronous XMLHttpRequest on the main thread is deprecated because of i ...

  7. Struts2漏洞

    近日,Struts2曝出2个高危安全漏洞,一个是使用缩写的导航参数前缀时的远程代码执行漏洞,另一个是使用缩写的重定向参数前缀时的开放式重定向漏洞.这些漏洞可使黑客取得网站服务器的“最高权限”,从而使企 ...

  8. VC++ Debug格式化数值显示

    When you watch variables in the Watch or Quick Watch window, the values are displayed using the defa ...

  9. Linux查看网络和IO性能问题

    Linux上使用iftop可以查看网络使用情况,使用iotop可以查看磁盘io使用情况 首先需要安装iftop和iotop: yum install iftop yum install iotop = ...

  10. 10招步骤保护IIS服务器安全

    问题 IIS(Internet Information Server)是黑客特别喜欢的目标.因此,对于管理IIS网页服务器的管理员来说,确保服务器安全是一件至关重要的事.IIS 4.0和IIS 5.0 ...