tornado_请求与响应

认识请求与响应

浏览器是如何能访问到服务器的?服务器又是怎样给浏览器回应的?
当我们在浏览器里输入网址时,浏览器会根据域名解析找到对应的IP地址,然后会与web服务器建立一个TCP连接,当连接建立好之后浏览器会给web服务器发送一个http请求。之后服务器会给浏览器响应一个301永久重定向响应。


request
请求(客户端---服务器)

一个http请求报文由请求行<request-line>、请求头部<headers>、空行<blank-line>和请求数据<request-body>4个部分组成

  • 请求头
Accept: 浏览器可以接受的MIME类型。
Accept-Charset: 浏览器支持的字符集
Accept-Encoding: 浏览器能够解码的数据压缩方式
Accept-language: 所希望的语言
Host: 请求的主机和端口
User-Agent: 通知服务器,浏览器类型.
Content-Length: 表示请求消息正文的长度
Connection: 表示是否需要持久连接(Keep-alive)
Cookie: 最重要的请求头信息之一
  • 请求行
<!-- 请求行,位于第一行 -->
Method: 一般为 GET 或者 POST
Path-to-resource:请求的资源的URI
Http/Version-number:客户端使用的协议的版本,例:HTTP/1.1
  • 请求正文

请求具体内容,比如:URL中传入的参数,form表单里面的内容等


response
响应(服务器---客户端)

一个http响应报文由状态行<status-line>、响应头部<headers>、空行<blank-line>和响应数据<response-body>4个部分组成

  • 响应头
Server: 通知客户端,服务器的类型
Content-Encoding: 响应正文的压缩编码方式。
Content-Length: 通知客户端响应正文的数据大小
Content-Type: 通知客户端响应正文的MIME类型
Content-Disposition: 通知客户端,以下载的方式打开资源

-响应行

Http/Version-number:服务器用的协议版本�
Statuscode:响应码。
  • 响应正文

具体的响应内容,如html,JavaScript 等数据内容

常见状态码

状态码.png

设置响应头

为什么请求头我们设置,而是设置的响应头?
请求头是浏览器发过来的,不受服务器控制的,我们能控制的就是响应头。

set_header
设置响应头,相同响应头名字只允许设置一个

add_header
添加响应头,相同响应头名字允许存在多个

clear_header
清除响应头

class MainHandler(tornado.web.ReqeustHandler):
    def get(self):
        self.set_headers('name', 'xiaoming')  # 设置响应头
        self.set_headers('age', '18')
        
        self.add_headers('name', 'jack')  # 添加响应头
        self.add_headers('name', 'rose')
        
        self.clear_headers('age')  # 清除响应头
        self.clear_headers('name')

发送错误码

send_error
主动让浏览器抛出错误

write_error
自定义报错信息

set_status
自定义设置状态码

class MainHandler(tornado.web.RequestHandler):
    def get(self):
        self.write('Life is short You need python')
        # self.flush()  
# 刷新,输出到浏览器,此时状态码为 200:OK
# 已经变成了既定的事实了,所以无法改变

        self.send_error(404)  # 让浏览器主动报错(404: Not Found)
        self.set_status(500, 'OK')  # 设置状态码
        
    def write_error(self, status_code, **kwargs):
                """重写write_error自定义报错信息"""
        self.write('报错码为:%s,错误信息为:Not Found' % status_code)
        # self.render('error.html')


app = Application([
        (r'/', MainHandler),
    ])  

上述我们说的是发送错误码自定义报错

除此之外,我们还可以通过添加一个Handler,然后返回一个自己写好的错误页面用来进行对未定义路由的处理

class NotHandler(tornado.web.RequestHandler):
    """自定义404的一个Handler"""
    def get(self, *args, **kwargs):
        self.render('error.html')


app = Application([
        (r'/(.*)', NotHandler)
    ])

请求与响应的执行流程

tornado 在接受到请求之后,会按照此顺序选择响应的方法来执行

class MainHandler(tornado.web.RequestHandler):
    
    def set_default_headers(self):
        """设置默认响应头"""
        pass
    
    def initialize(self):
        """初始化"""
        pass
    
    def prepare(self):
        """准备工作"""
        pass
    
    def get(self):
        self.write('hello world')
    
    def post(self):
        pass
    
    def write_error(self):
        """处理错误信息"""
        pass
    
    def on_finish(self):
        """结束并且释放资源"""
        pass

推荐阅读更多精彩内容

  • 浏览器与服务器之间通信 请求信息 浏览器在发送请求的时候,会发送具体的请求信息,由请求行,请求消息头,请求正文。 ...
    Python野路子阅读 2,301评论 0 51
  • API定义规范 本规范设计基于如下使用场景: 请求频率不是非常高:如果产品的使用周期内请求频率非常高,建议使用双通...
    有涯逐无涯阅读 2,326评论 0 6
  • 第一部分 HTML&CSS整理答案 1. 什么是HTML5? 答:HTML5是最新的HTML标准。 注意:讲述HT...
    kismetajun阅读 26,676评论 1 45
  • 深入浅出HTTP协议(WEB开发和面试必备) 1.基础概念篇 a.简介 HTTP是Hyper Text Trans...
    半世韶华忆阑珊阅读 1,154评论 0 7
  • arp的几个命令容易混淆,一下做记录: arp arp(address resolution protocol)协...
    hades2013阅读 869评论 0 0