浏览器与服务器之间通信
请求信息
浏览器在发送请求的时候,会发送具体的请求信息,由请求行,请求消息头,请求正文。
请求行
请求行,位于第一行,包含内容为:
Method: 一般为 GET 或者 POST
Path-to-resource:请求的资源的URI
Http/Version-number:客户端使用的协议的版本,有HTTP/1.0和HTTP/1.1
请求消息头
向服务器传递附加信息
Accept: 浏览器可以接受的MIME类型。
Accept-Charset: 浏览器支持的字符集,如gbk,utf-8
Accept-Encoding: 浏览器能够解码的数据压缩方式, 如:gzip
Accept-language: 所希望的语言
Host:请求的主机和端口User-Agent:通知服务器,浏览器类型.
Content-Length:表示请求消息正文的长度
Connection:表示是否需要持久连接(Keep-alive)
Cookie:这是最重要的请求头信息之一(会话有关)
请求正文
请求具体内容,比如: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 等数据内容。
设置响应头
在请求与响应当中,请求是浏览器设置的,在服务器端只能接受,无法改变,但是在响应头可以设置。
set_header
set_header 可以设置响应头。
class HeaderHandler(tornado.web.RequestHandler):
def get(self):
self.write("set header")
self.set_header('aaa','111') #set_header 可以设置响应头
self.set_header('bbb','222') #可以设置多个
self.set_header('aaa','333') #同name的后面的会覆盖前面的,aaa只显示这个value
add_header
add_header 可以向响应头里面添加信息,而且是可以出现相同信息。
self.add_header('bbb','444') #add_header 可以向响应头里面添加信息,而且是可以出现相同信息,不会出现覆盖
clear_header
clear_header 可以撤销给定的响应头信息
self.clear_header('bbb') #将2个bbb清除
发送错误码
send_error
可以将指定的 HTTP 错误码发送到浏览器。
class ErrorHandler(tornado.web.RequestHandler):
def get(self):
self.write('send error')
self.send_error(404)
如果输出已写入但尚未刷新,则将其丢弃并替换为错误页面,如上。
使用 send_error 时需要注意:如果已经执行了 flush,则不能再执行 send_error,因此该方法将简单地终止响应。
class ErrorHandler(tornado.web.RequestHandler):
def get(self):
self.write('send error')
self.flush() #使用 send_error 时需要注意:如果已经执行了 flush,则不能再执行 send_error,因此该方法将简单地终止响应
self.send_error(404)
实现自定义错误页面
send_error
在其底层调用的是write_error
因此只要重写此方法,就可以实现自定义的的错误页面。
class ErrorHandler(tornado.web.RequestHandler):
def get(self):
self.write('send error')
# self.flush() #使用 send_error 时需要注意:如果已经执行了 flush,则不能再执行 send_error,因此该方法将简单地终止响应
self.send_error(404)
def write_error(self, status_code, **kwargs):#send_error 在其底层调用的是 write_error,因此只要重写此方法,就可以实现自定义的的错误页面
self.write('页面被喵星人吃了!')
未定义路由处理
有时候如果请求的资源页面不存在,需要人性化提示,可以通过路由执行顺序,自上而下匹配,到最后没有匹配上的,走最后的处理,需要把此路由放到路由表的最后面,通过这种方式,可以让返回自定义的错误页面
class NotFoundHandler(tornado.web.RequestHandler):
def get(self):
self.send_error(505)
def write_error(self, status_code, **kwargs):
self.render('not_page.html')
application = tornado.web.Application(
handlers = [
(r'/',HeaderHandler),
(r'/senderror',ErrorHandler),
(r'/(.*)', NotFoundHandler)
],
template_path = 'templates', #想要Tornado能够正确的找到html文件,需要在 Application 中指定文件的位置
debug = True #调试模式,修改后自动重启服务,不需要自动重启,生产情况下切勿开启,安全性
)
请求处理过程
Tornado 在接受到请求之后,后按照此顺序选择响应的方法来执行
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---:结束,释放资源')