tornado请求与响应相关

一、配置文件config.py 中的settings 有哪些配置:

  • debug:设置tornado是否工作再调试模式下,默认为false 即工作再生产模式下

    • true的特性: tornado 应用会监控源代码文件,当有保存改动时,会重新启动服务器

      • 如果保存后代码有错误,会重启失败,修改后需要手动重启
      • 取消缓存编译的模板--->compiled_template_cache = False 单独设置
      • 取消缓存静态文件的hash值 -->static_hash_cache = False 单独设置
      • 提供追踪信息 --> server_traceback = False 单独设置
      • autoreload = True ==》仅仅用自动重启
  • static_path:设置静态文件目录
  • tempalte_path:设置模板文件目录

二、tornado 中的路由

# -*- coding: utf-8 -*-

import tornado.web

from views import index
import config class Application(tornado.web.Application):
def __init__(self):
handlers = [
(r'/', index.IndexHandler),
(r'/login', index.LoginHandler, {'name': 'qzk', 'pwd': '123'}),
(r'/json', index.JsonResponseHandler), # 返回json格式的视图
(r'/header', index.HeaderHandler), # 修改响应头的视图
(r'/status', index.StatusHandler), # 修改状态码的视图
(r'/redirect', index.RedirectHandler), # 重定向的视图
(r'/error/', index.ErrorHandler), # 自定义错误的状态码以及信息的是视图
]
super(Application, self).__init__(handlers, **config.settings)
# -*- coding: utf-8 -*-
from tornado.web import RequestHandler class IndexHandler(RequestHandler):
def get(self, *args, **kwargs):
self.write("ojbk") class LoginHandler(RequestHandler):
def get(self,*args,**kwargs):
self.write('qwer')

三、利用wirte方法写json数据

  • 注意:自己手动序列化json方式 前端response headers 中的 Content_Type属性text/html,而采用write自动序列化方式,Content_Type属性为application/json
class JsonResponseHandler(RequestHandler):
def get(self,*args,**kwargs):
response = {
"name":"qzk",
"password":"123"
}
self.write(response)
# 上述方式返回的是 json对象类型 import json
class JsonResponseHandler(RequestHandler):
def get(self,*args,**kwargs):
response = {
"name":"qzk",
"password":"123"
}
response_str = json.dumps(response)
self.write(response_str)
# 上述方式返回的 text/html 对象类型

四、设置响应头(self.set_header(name,value))

  • 作用:设置响应的头文件(手动设置一个名为name,值value的字段)
  • 参数: name ,value
import json
class JsonResponseHandler(RequestHandler):
def get(self,*args,**kwargs):
response = {
"name":"qzk",
"password":"123"
}
response_str = json.dumps(response)
self.set_header("Content_Type","application/json;charset=UTF-8")
self.set_header("qzk","dsb")
self.write(response_str)
响应结果:
Response Headers:
Content-Length: 34
Content-Type: application/json;charset=UTF-8
Date: Mon, 12 Aug 2019 12:14:31 GMT
Etag: "df54410c9849c29be64aee44631769c071dd82bd"
Qzk: dsb
Server: TornadoServer/6.0.2

五、default_headers()-->规范默认修改响应的头的位置

  • 作用:在进入http响应处理方法之前被调用执行的
  • 注意: 在http处理方法中再使用 self.set_headers() 方法 设置通用的name的值,会覆盖原先在set_default_headers() 中设置的值
class HeaderHandler(RequestHandler):

    def set_default_headers(self):
# 默认修改响应的头都在这边修改
self.set_header("Content-Type", "application/json;charset=UTF-8")
self.set_header("qzk", "dsb") def get(self, *args, **kwargs):
response = {
"name": "qzk",
"password": "456"
}
response_str = json.dumps(response)
self.write(response_str)
响应头
Response Headers:
Content-Length: 34
Content-Type: application/json;charset=UTF-8
Date: Mon, 12 Aug 2019 12:25:32 GMT
Etag: "76512585c844435efcbb60337298886e7e7b9ad3"
Qzk: dsb
Server: TornadoServer/6.0.2

六、self.set_status(status_code,reason=None)

  • 作用:为响应设置状态码
  • 参数:
    • status--状态码的值为 int类型
    • reason--对状态码的描述 str类型 如果reason值为None 则状态码的值必须为正常值
# -*- coding: utf-8 -*-
from tornado.web import RequestHandler class IndexHandler(RequestHandler):
def get(self, *args, **kwargs):
self.write("ojbk") class LoginHandler(RequestHandler): def initialize(self, name, pwd):
"""该方法在执行get之前先执行"""
self.name = name
self.pwd = pwd def get(self, *args, **kwargs):
print(self.name, self.pwd)
self.write(self.name) import json class JsonResponseHandler(RequestHandler):
def get(self, *args, **kwargs):
response = {
"name": "qzk",
"password": "123"
}
response_str = json.dumps(response)
self.set_header("Content-Type", "application/json;charset=UTF-8")
self.set_header("qzk", "dsb")
self.write(response_str) class HeaderHandler(RequestHandler): def set_default_headers(self):
# 默认修改响应的头都在这边修改
self.set_header("Content-Type", "application/json;charset=UTF-8")
self.set_header("qzk", "dsb") def get(self, *args, **kwargs):
response = {
"name": "qzk",
"password": "456"
}
response_str = json.dumps(response)
self.write(response_str) class StatusHandler(RequestHandler): def set_default_headers(self):
# 默认修改响应的头都在这边修改
self.set_header("Content-Type", "application/json;charset=UTF-8")
self.set_header("qzk", "dsb") def get(self, *args, **kwargs):
# self.set_status(404) # 404 为系统的正常的状态码,reason可以为 None
self.set_status(999) # 999 系统不存在该状态码,因此需要设置reason,否则报错
self.write('**************')
"""
Request URL: http://127.0.0.1:8982/status
Request Method: GET
Status Code: 999 Unknown
Remote Address: 127.0.0.1:8982
Referrer Policy: no-referrer-when-downgrade 服务器端报错:
ERROR:tornado.access:999 GET /status (127.0.0.1) 1.00ms
"""

七、重定向 -- self.redirect(url)

  • 作用:重定向到url网站
class RedirectHandler(RequestHandler):
def get(self):
self.redirect('/')
响应头:
General:
Request URL: http://127.0.0.1:8983/redirect
Request Method: GET
Status Code: 302 Found
Remote Address: 127.0.0.1:8983
Referrer Policy: no-referrer-when-downgrade

八、self.send_error(status_code=500,**kwargs)

  • 作用:可以跑出http错误状态码,默认为500,跑出错误后tornado会调用write_error()方法处理,并返回给浏览器界面
  • 注意: 在send_error 之下,就不要在响应输出了,不执行之下的内容

九、write_error(status_code,**kwargs)

  • 用来处理send_error跑出来的额信息,并返回给浏览器错误页面
class ErrorHandler(RequestHandler):
def write_error(self, status_code: int, **kwargs):
if status_code == 404:
code = 404
# 正常情况下返回的自定义的404页面
self.write('资源部存在')
elif status_code == 500:
code = 500
self.write('服务器错误')
self.set_status(code) def get(self, *args, **kwargs):
flag = self.get_query_argument('flag')
if flag == '0':
self.send_error(404)
self.write('you are sb')
Request URL: http://127.0.0.1:8983/error/?flag=0
Request Method: GET
Status Code: 404 Not Found
Remote Address: 127.0.0.1:8983
Referrer Policy: no-referrer-when-downgrade

tornado的请求与响应的更多相关文章

  1. tornado 03 请求与响应

    tornado 03 请求与响应 一.请求与响应 浏览器与服务器之间沟通的到底是什么信息 #服务器在后台一直保持运行着 #浏览器通过URL(路由.地址)发送请求 #服务器接收请求了通过tornado处 ...

  2. 2.(基础)tornado的请求与响应

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

  3. 2.tornado请求与响应

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

  4. tornado请求与响应

    tornado中处理请求与响应的类如下, 所有视图类必须继承该类: tornado.web.RequestHandler 一. 响应之self.write()方法 1.  该方法可返回值的类型: 当返 ...

  5. Django底层剖析之一次请求到响应的整个流程

    As we all know,所有的Web应用,其本质上其实就是一个socket服务端,而用户的浏览器就是一个socket客户端. #!/usr/bin/env python #coding:utf- ...

  6. 初入网络系列笔记(4)HTTP请求和响应

    一.借鉴说明,本博文借鉴以下博文 1.starok,HTTP必知必会,http://www.cnblogs.com/starstone/p/4890409.html 2.CareySon,HTTP协议 ...

  7. http协议(二)请求和响应报文的构成

    http协议用于客户端和服务器之间的通信,请求访问资源的一方称为客户端,而提供资源响应的一方称为服务器端. 下面就是客户端和服务端之间简单的通信过程 PS:请求必须从客户端建立通信,服务端没收到请求之 ...

  8. iOS开发——网络篇——HTTP/NSURLConnection(请求、响应)、http响应状态码大全

    一.网络基础 1.基本概念> 为什么要学习网络编程在移动互联网时代,移动应用的特征有几乎所有应用都需要用到网络,比如QQ.微博.网易新闻.优酷.百度地图只有通过网络跟外界进行数据交互.数据更新, ...

  9. struts2基础——请求与响应、获取web资源

    一.请求与响应 Action1.含义:(1) struts.xml 中的 action 元素,也指 from 表单的 action 属性,总之代表一个 struts2 请求.(2) 用于处理 Stru ...

随机推荐

  1. 26.Java基础_状态修饰符

    状态修饰符: final(最终态),static(静态) final关键字: 修饰类: 修饰局部变量: static关键字: 修饰变量:   修饰函数:

  2. 【CF981F】Round Marriage(二分答案,hall定理)

    传送门 题意: 给出一个长度为\(L\)的环,标号从\(0\)到\(L-1\). 之后给出\(n\)个新郎,\(n\)个新娘离起点的距离. 现在新郎.新娘要一一配对,但显然每一对新人的产生都会走一定的 ...

  3. Html学习之十(CSS选择器的使用--伪类选择器)

    伪类选择器 一.基于a标签. 1.:hover 选择鼠标滑过的超链接元素 2.:active 选择鼠标单击中的超链接元素 3.:link 选择未被访问的超链接元素 4.:visited 选择已经被访问 ...

  4. 用背包问题思路解决 322. Coin Change(完全背包)

    首先需要明白 0-1 背包问题中的放置表格,见 “玩转算法面试 从真题到思维全面提升算法思维” 9-5 节,本题思路类似表格纵向为:只考虑第 [0 …,… index] 种硬币(物品)表格横向为:需要 ...

  5. 解决问题:Unable to start ServletWebServerApplicationContext due to missing ServletWebServerFactory bean.

    Unable to start ServletWebServerApplicationContext due to missing ServletWebServerFactory bean. 注释掉, ...

  6. thinkphp6报错Driver [Think] not supported.

    解决方法 composer require topthink/think-view

  7. 关于XSS攻击

    1.XSS XSS(Cross Site Scripting)攻击全称跨站脚本攻击,为了不与CSS(Cascading Style Sheets)混淆,故将跨站脚本攻击缩写为XSS,XSS是一种经常出 ...

  8. Paper | Feedback Networks

    目录 读后总结 动机 故事 ConvLSTM图像分类网络 损失函数 与Episodic Curriculum Learning的结合 实验方法 发表在2017年CVPR. 读后总结 这篇论文旨在说明: ...

  9. sessionStorage 、localStorage 、 cookie 和session之间的区别

    四者的异同 特性 Session   Cookie localStorage sessionStorage 数据的生命期   在一定时间内保存在服务器上.当访问增多,会比较占用你服务器的性能,考虑到减 ...

  10. Tomca原理分析之责任链

    责任链使用位置:Container处理请求 Container处理请求是使用Pipeline-Valve管道来处理的!(Valve是阀门之意) Pipeline-Valve是责任链模式,责任链模式是指 ...