tornado的请求与响应
tornado请求与响应相关
一、配置文件config.py 中的settings 有哪些配置:
- debug:设置tornado是否工作再调试模式下,默认为false 即工作再生产模式下
- true的特性: tornado 应用会监控源代码文件,当有保存改动时,会重新启动服务器
- 如果保存后代码有错误,会重启失败,修改后需要手动重启
- 取消缓存编译的模板--->compiled_template_cache = False 单独设置
- 取消缓存静态文件的hash值 -->static_hash_cache = False 单独设置
- 提供追踪信息 --> server_traceback = False 单独设置
- autoreload = True ==》仅仅用自动重启
- true的特性: tornado 应用会监控源代码文件,当有保存改动时,会重新启动服务器
- 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的请求与响应的更多相关文章
- tornado 03 请求与响应
tornado 03 请求与响应 一.请求与响应 浏览器与服务器之间沟通的到底是什么信息 #服务器在后台一直保持运行着 #浏览器通过URL(路由.地址)发送请求 #服务器接收请求了通过tornado处 ...
- 2.(基础)tornado的请求与响应
之前我们介绍了tornado 的基础流程,但是还遗留了一些问题,今天我们就来解决这些遗留问题并学习新的内容 settings,使用tornado.web.Application(handler, ** ...
- 2.tornado请求与响应
之前我们介绍了tornado的基础流程,但还遗留了一些问题.今天我们就来解决遗留问题并学习新的内容 settings,使用tornado.web.Application(handler, **sett ...
- tornado请求与响应
tornado中处理请求与响应的类如下, 所有视图类必须继承该类: tornado.web.RequestHandler 一. 响应之self.write()方法 1. 该方法可返回值的类型: 当返 ...
- Django底层剖析之一次请求到响应的整个流程
As we all know,所有的Web应用,其本质上其实就是一个socket服务端,而用户的浏览器就是一个socket客户端. #!/usr/bin/env python #coding:utf- ...
- 初入网络系列笔记(4)HTTP请求和响应
一.借鉴说明,本博文借鉴以下博文 1.starok,HTTP必知必会,http://www.cnblogs.com/starstone/p/4890409.html 2.CareySon,HTTP协议 ...
- http协议(二)请求和响应报文的构成
http协议用于客户端和服务器之间的通信,请求访问资源的一方称为客户端,而提供资源响应的一方称为服务器端. 下面就是客户端和服务端之间简单的通信过程 PS:请求必须从客户端建立通信,服务端没收到请求之 ...
- iOS开发——网络篇——HTTP/NSURLConnection(请求、响应)、http响应状态码大全
一.网络基础 1.基本概念> 为什么要学习网络编程在移动互联网时代,移动应用的特征有几乎所有应用都需要用到网络,比如QQ.微博.网易新闻.优酷.百度地图只有通过网络跟外界进行数据交互.数据更新, ...
- struts2基础——请求与响应、获取web资源
一.请求与响应 Action1.含义:(1) struts.xml 中的 action 元素,也指 from 表单的 action 属性,总之代表一个 struts2 请求.(2) 用于处理 Stru ...
随机推荐
- Python继承、多继承、魔术方法
继承和多继承的概念和使用 super的用法 __str__ __repr__ __call__ 多继承方法解析顺序和Mix-in开发模式 魔术方法原理和作用 继承 定义类的时候,在类名后面的括号里填继 ...
- luoguP1447 [NOI2010]能量采集
https://www.luogu.org/record/22874213 题目大意:给定n和m,求Σ(1<=i<=n)Σ(1<=j<=m)GCD(i,j)* 2-1 i和j的 ...
- JMeter jp@gc - stepping thread group插件
这是一个出单接口压力测试的小例子,了解一下压力测试最最基础的基础.出单接口是用来保险出单的,不需要在UI界面下一步下一步的出单,接口一调数据入库完事~~~.再啰嗦一句接口应该都知道是什么吧?一个完整的 ...
- 遗传算法求解旅行商(TSP)问题 -- python
参考资料: 遗传算法解决TSP旅行商问题(附:Python实现) 遗传算法详解(GA)(个人觉得很形象,很适合初学者) from itertools import permutations impor ...
- mysql里的insert
insert不跟where 比如 insert into table (name) value('******')where id =1 肯定不行的 insert 语句 是插入语句,不跟条件的. 如果 ...
- [PHP] laravel5.5 搭建流程
1.nginx 配置 server { listen 80; server_name laravel5-test.d.com; charset utf-8; location ...
- 【BZOJ3534】[SDOI2014] 重建(矩阵树定理)
点此看题面 大致题意: 给你一张图,每条边有一定存在概率.求存在的图刚好为一棵树的概率. 矩阵树定理是什么 如果您不会矩阵树定理,可以看看蒟蒻的这篇博客:初学矩阵树定理. 矩阵树定理的应用 此题中,直 ...
- 在windows上搭建git服务器教程
1.首先,需要确保windows系统上安装并配置了Java运行环境,JDK>=1.7. 2.下载Gitblit,下载地址:http://www.gitblit.com/ 3.解压缩下载的压缩包即 ...
- mysql百万级数据分页查询缓慢优化-实战
作为后端攻城狮,在接到分页list需求的时候,内心是这样的 画面是这样的 代码大概是这样的 select count(id) from … 查出总数 select * from …. li ...
- Autoware 培训笔记 No. 3——录制航迹点
1.前言 航迹点用于知道汽车运行,autoware的每个航迹点包含x, y, z, yaw, velocity信息. 航迹点录制有两种方式,可以开车录制航迹点,也可以采集数据包,线下录制航迹点,我分开 ...