01 请求与响应
请求
浏览器在发送请求的时候,会发送具体的请求信息,由请求行,请求消息头,请求正文
请求消息头
向服务器传递附加信息
Accept: 浏览器可以接受的MIME类型。
Accept-Charset: 浏览器支持的字符集,如gbk,utf-8
Accept-Encoding: 浏览器能够解码的数据压缩方式, 如:gzip,deflate
Accept-language: 所希望的语言
Host:请求的主机和端口
User-Agent:通知服务器,浏览器类型.
Content-Length:表示请求消息正文的长度
Connection:表示是否需要持久连接(Keep-alive)
Cookie:这是最重要的请求头信息之一(会话有关)
请求行 #在request header右边view parsed
请求行,位于第一行,包含内容为:
Method: 一般为 GET 或者 POST
Path_to_resource:请求的资源的URI
Http/Version-number:客户端使用的协议的版本,有HTTP/1.0和HTTP/1.1
请求正文
请求具体内容,比如:URL中传入的参数,form表单里面的内容等等
响应信息
响应信息为服务器的处理结果。主要包含:响应行,响应消息头,响应正文
响应行
响应行主要报错如下信息:
Http/Version-number:服务器用的协议版本
Statuscode:响应码。代表服务器处理的结果的一种表示,常用的响应码有
200:正常
302/307:重定向
304:服务器的资源没有被修改
404:请求的资源不存在
500:服务器报错了 message
:响应码描述。例如200的描述为OK
响应头
Server: 通知客户端,服务器的类型
Content-Encoding:响应正文的压缩编码方式。常用的是gzip
Content-Length:通知客户端响应正文的数据大小
Content-Type:通知客户端响应正文的MIME类型
Content-Disposition:通知客户端,以下载的方式打开资源
响应正文:
具体的响应内容,如html,JavaScript 等数据内容
02 设置响应头
设置给定响应头
Handler
class HeaderHandler(tornado.web.RequestHandler):
def get(self):
self.write('set_header')
self.set_header('aaa', '1111')
self.set_header('bbb', '2222')
self.set_header('bbb', '3333')
set_header
set_header 可以设置响应头,如果设置两个一样响应头,会以后面的值为准.响应头控制浏览器的一些行为.
添加给定响应头
Handler
class AddHandler(tornado.web.RequestHandler):
def get(self):
self.write('add_header')
self.add_header('ccc', '3333')
self.add_header('ccc', '4444')
add_header
add_header 可以向响应头里面添加信息,而且是可以出现相同信息
撤销给定响应头
Handler
class CleanHandler(tornado.web.RequestHandler):
def get(self):
self.write('clear_heander')
self.add_header('abcd', '5555')
self.add_header('abcd', '6666')
self.clear_header('abcd') l
clear_header
clear_header 可以撤销给定的响应头信息,多个同名的响应头一次删除.
03 发送错误码
发送错误码到浏览器
Handler
class SendHandler(tornado.web.RequestHandler):
def get(self):
self.write('send_error')
#self.flush()
self.send_error(404)
使用 send_error 时需要注意:如果已经执行了 flush,则不能再执行 send_error,因此该方法将简单地终止响应,如果输出已写入但尚未刷新,则将其丢弃并替换为错误页面
send_error
send_error 可以将指定的 HTTP 错误码发送到浏览器
实现自定义错误页面
Handler
def write_error(self, status_code, **kwargs):
self.write('status_code: %s' % status_code)
write_error
send_error 在其底层调用的是 write_error,因此只要重写此方法,就可以实现自定义的的错误页面
未定义路由处理
Handler
class NotFoundHandler(tornado.web.RequestHandler):
def get(self, *args, kwargs):
** self.send_error(404)
def write_error(self, status_code, **kwargs):
self.render('error_notfound.html')
路由
(r'/(.*)', NotFoundHandler)
用正则匹配出来的路由要用*args,**kwargs路由接收.
self.set_status(404,'error message')直接设置状态码.
自定义错误页面
注意:需要把此路由放到路由表的最后面,通过这种方式,可以让返回自定义的错误页面
04 请求处理过程
Handler
class IndexHandler(tornado.web.RequestHandler):
def set_default_headers(self):
print(' ---set_default_headers---:设置header')
def initialize(self):
print(' ---initialize---:初始化')
def prepare(self):
print(' ---prepare---:准备工作')
def get(self):
self.write(' ---get---:处理get请求'+' ')
def post(self):
self.write(' ---post---:处理post请求'+' ')
def write_error(self, status_code, **kwargs):
print(' ---write_error---:处理错误')
def on_finish(self):
print(' ---on_finish---:结束,释放资源') l
调用顺序
Tornado 在接受到请求之后,会按照此顺序选择响应的方法来执行