1.输出

再来看看输出`write`,实际上,`write`并没有直接把数据返回给前端,而是先写到缓存区,函数结束之后才会返回到前端,我们验证如下

class FlushHandler(tornado.web.RequestHandler):
def get(self):
self.write('this is '+'<br>')
self.write('tornado'+'<br>')
self.flush()
import time
time.sleep(5)
self.write('hahaha')
self.flush()
self.write('en~~~~')

这里我们可以很明显看到,在有无`self.flush()`的时候,结果是不一样的。如果有的话,就可以先看到前面的输出,没有的话,要等到函数执行完才能够一起打印出来 。`self.flush()`就是将当前输出缓冲区刷新到网络。

除了上面的`self.flush()`之外,还有`self.finish()`需要我们注意,它就类似于函数里面的`return`,一旦执行,后面就不能再执行`self.write`,函数原型:

[`RequestHandler.finish(chunk = None)`](http://www.tornadoweb.org/en/stable/_modules/tornado/web.html#RequestHandler.finish)

在finish函数调用完后,调用write函数会报错

self.finish()
self.write('en~~~~')

**将给定的HTTP错误发送到浏览器**

[`RequestHandler.send_error(status_code = 500,**kwargs) `](http://www.tornadoweb.org/en/stable/_modules/tornado/web.html#RequestHandler.send_error)

如果[`flush()`](http://www.tornadoweb.org/en/stable/web.html#tornado.web.RequestHandler.flush)已经被调用,则不可能发送错误,因此该方法将简单地终止响应。如果输出已写入但尚未刷新,则将其丢弃并替换为错误页面。

覆盖[`write_error()`](http://www.tornadoweb.org/en/stable/web.html#tornado.web.RequestHandler.write_error)以自定义返回的错误页面。传递附加的关键字参数

self.send_error(404)  #如果已经执行 self.flush() 则不会不能显示错误

**覆盖以实现自定义错误页面**

函数原型:

[`RequestHandler.write_error(*status_code*,**\* kwargs *)`](http://www.tornadoweb.org/en/stable/_modules/tornado/web.html#RequestHandler.write_error)

`write_error`可以调用[`write`](http://www.tornadoweb.org/en/stable/web.html#tornado.web.RequestHandler.write),[`render`](http://www.tornadoweb.org/en/stable/web.html#tornado.web.RequestHandler.render),[`set_header`](http://www.tornadoweb.org/en/stable/web.html#tornado.web.RequestHandler.set_header)等,以产生输出。

def write_error(self, status_code, **kwargs):
self.write("---%d----\n"%status_code)

通过重写`write_error`方法,可以实现自定义的输出错误。

**设置响应的状态代码**

[`RequestHandler.set_status(status_code,reason = None)`](http://www.tornadoweb.org/en/stable/_modules/tornado/web.html#RequestHandler.set_status)

参数:

\- status_code(int) - 响应状态码。

\- reason(string) - 描述状态代码的人类可读原因短语。

self.set_status(404,'error')

2.响应头的设置

以谷歌浏览器为例:按下F12,可以打开浏览器自带的控制台,我们选择Network,这里我们可以看到浏览器在页面上没有看到的信息。打开之后刷新一下,选择之后就可以看到:`General`,`Respnse Headers`和`Request Headers`

`General`:是请求中基本信息,`Respnse Headers`是相应信息,`Request Headers`是请求信息,在服务器端可以设置给浏览器的相应信息。

(r'/header',HeadersHandler),
class HeadersHandler(tornado.web.RequestHandler):
def get(self):
self.write('headers')
self.set_header('budong',18)
self.set_header('changsha','hunan')

函数原型:

[`RequestHandler.set_header(name, value)`](http://www.tornadoweb.org/en/stable/_modules/tornado/web.html#RequestHandler.set_header)

如果值不是字符串,我们将其转换为字符串。然后将所有标题值编码为UTF-8

`self.set_header`可以设置自己的需要的响应头

**添加给定的响应头和值**

函数原型:

[`RequestHandler.add_header(*name*, *value*)`](http://www.tornadoweb.org/en/stable/_modules/tornado/web.html#RequestHandler.add_header)

不同[`set_header`](http://www.tornadoweb.org/en/stable/web.html#tornado.web.RequestHandler.set_header),[`add_header`](http://www.tornadoweb.org/en/stable/web.html#tornado.web.RequestHandler.add_header)可能会多次调用以返回相同键的多个值。相同的键`set_header`只能返回一个值

self.set_header('jingqi','20')
self.add_header('jingqi','19')
self.add_header('jingjing','0731')

**撤消先前的set_header调用**

有添加,就会有删除,函数原型:

[`RequestHandler.clear_header`(*name*)](http://www.tornadoweb.org/en/stable/_modules/tornado/web.html#RequestHandler.clear_header)

self.clear_header('changsha')

**相应头的执行顺序**

class IndexHandler(tornado.web.RequestHandler):
def set_default_headers(self):
print(' ---set_default_headers---:设置header'+'<br>') def initialize(self):
print(' ---initialize---:初始化'+'<br>') def prepare(self):
print(' ---prepare---:准备工作'+'<br>') def get(self):
self.write(' ---get---:处理get请求'+'<br>') def post(self):
self.write(' ---post---:处理post请求'+'<br>') def write_error(self, status_code, **kwargs):
print(' ---write_error---:处理错误'+'<br>') def on_finish(self):
print(' ---on_finish---:结束,释放资源'+'<br>')

Tornado输出和响应头的更多相关文章

  1. 接口测试——HttpClient工具的https请求、代理设置、请求头设置、获取状态码和响应头

    目录 https请求 代理设置 请求头设置 获取状态码 接收响应头 https请求 https协议(Secure Hypertext Transfer Protocol) : 安全超文本传输协议, H ...

  2. tornado 响应头 中断 状态码 工作流程

    set_header    设置响应头 clear_header 清除响应头 add_header   增加响应头 self.flush  self.finish  中断 set_status     ...

  3. 2.tornado请求与响应

    之前我们介绍了tornado的基础流程,但还遗留了一些问题.今天我们就来解决遗留问题并学习新的内容 settings,使用tornado.web.Application(handler, **sett ...

  4. PHP--获取响应头(Response Header)方法

    方法一: $baiduUrl = "http://www.baidu.com/link";   file_get_contents($baiduUrl); $responseInf ...

  5. 移除IIS默认的响应头(转载)

    转载地址:http://www.cnblogs.com/dudu/p/iis-remove-response-readers.html 在IIS+ASP.NET的运行环境,默认情况下会输出以下的响应头 ...

  6. 转:PHP--获取响应头(Response Header)方法

    转:http://blog.sina.com.cn/s/blog_5f54f0be0102uvxu.html PHP--获取响应头(Response Header)方法 方法一: ========== ...

  7. 服务器响应头隐藏X-power-by

    服务器响应头隐藏X-power-by 这个不是Apache或者Nginx输出的,而是由语言解析器或者应用程序框架输出的. 这个值的意义用于告知网站是用何种语言或框架编写的.例如: PHP标准输出是:X ...

  8. Android系列之网络(二)----HTTP请求头与响应头

    ​[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/ ...

  9. 移除IIS默认的响应头

    在IIS+ASP.NET的运行环境,默认情况下会输出以下的响应头(Response Headers): 那如何移除这些响应头呢?下面我们来一个一个移除. 1. 移除Server 借助IIS URL R ...

随机推荐

  1. poj 3253超时

    哈夫曼树超时是因为每次都需要重排,十分浪费时间,即使是快排.

  2. UDP协议----简单的CS模型实现

    UDP简单介绍 传输层主要应用的协议模型有两种,一种是TCP协议,另外一种则是UDP协议.TCP协议在网络通信中占主导地位,绝大多数的网络通信借助TCP协议完成数据传输.但UDP也是网络通信中不可或缺 ...

  3. iOS开发进阶 - 使用Carthage管理iOS第三方库

    移动端访问不佳,请访问我的个人博客 最近在研究Swift,一不小心发现一个好的的管理iOS第三方库Carthage,就跟第一次使用CocoaPods时一样兴奋不已,在研究了大半天后终于能用了,使用起来 ...

  4. 通过代码来调用log4net写日志

    1.使用如下配置 http://www.cnblogs.com/chucklu/p/5404813.html 2.调用 string ConfigFile; private void LoadLogC ...

  5. skynet 创建存储过程脚本

    最近主程更改了数据库的操作方案,由之前的拼写sql脚本转为在mysql端创建好存储过程后,直接调用存储过程. 首先对一个表测试上述过程: 数据库端存储过程:(测试表) CREATE TABLE `ra ...

  6. istringstream 用法

    istringstream 类用于执行C++风格的串流的输入操作 istringstream用空格作为字符串分隔符 #include <iostream>#include <sstr ...

  7. 关于EventBus3.0使用,你看这篇就够了

    作为一枚Android开发者,关于EventBus相信应该都听说过.要是用过就请忽略本文,本文讲得比较基础. 要是没用过,建议你花两分钟看看. 目前EventBus最新版本是3.0,本demo基于3. ...

  8. 关于shortcut icon和icon代码的区别介绍

    语句一:<link rel="shortcut icon" href="favicon.ico" /> 语句二:<link rel=" ...

  9. window.location.href无法跳转

    onclick事件存在事件冒泡 所以要阻止它冒泡 解决:在onclick事件里添加return false阻止冒泡:onclick="window.location.href='XXXXX. ...

  10. //可以不保存在session中, 并且前面我保存在request,这里session也可以获取 chain.doFilter(request, response); //只有登录名不为空时放行,防止直接登录 成功的页面

    public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOE ...