基于IOLoop的Web Server
来源:互联网 发布:中金交易软件 编辑:程序博客网 时间:2024/06/05 04:51
上次介绍了如何使用Flask来实现Web Server,这次使用另外一种方法,IOLoop的方式实现Web Server功能。
直接上一个简单的helloworld的demo。
import tornado.ioloopimport tornado.webimport jsonfrom tornado.web import RequestHandlerfrom tornado.web import Applicationfrom tornado.ioloop import IOLoopclass HelloWorldHandler(RequestHandler): def initialize(self): print("create new handler") def get(self): self.write("Hello world, " + self.get_argument('msg')) def post(self): msg = json.loads(str(self.request.body, encoding = "utf-8")) print(type(msg)) self.write('Hello world, ' + msg['msg'])application = Application([ (r'/', HelloWorldHandler),])if __name__ == "__main__": application.listen(8888) IOLoop.instance().start()
在实现RequestHandler的过程中最好不要Override它的__init__方法,在__init__方法内留有了可供扩展的初始化接口initialize,实现这个方法就能实现初始化状态的操作。
需要注意的一个特点就是,IOLoop每监听到一个请求之后就会创建一个对应的Handler来处理这个请求,所以Handler不是单例的。
demo分别实现了get和post两种方法,直接在浏览器地址栏访问http://localhost:8888/?msg=Johnson 可以调用get方法,利用Postman可以发送以下json到http://localhost:8888/实现调用。
{"msg":"johnson"}
Thanks
阅读全文
0 0
- 基于IOLoop的Web Server
- tornado-ioloop的理解
- 基于epoll的web server
- 基于uClinux的Web Server的实现
- 基于RL-TCPnet的Web Server应用
- 基于CGI的嵌入式web server设计
- 基于Linux的多线程Web Server
- [转]tornado ioloop start 的过程
- 14.Tornado高性能的秘密:ioloop对象分析 (副标题:IOLoop是个事件循环)
- Tornado高性能的秘密:ioloop对象分析 (副标题:IOLoop是个事件循环)
- 一个简单的基于epoll的web server
- 一个简单的基于多线程的web server
- 一个简单的基于多线程的web server
- 一个简单的基于epoll的web server
- 基于SQL Server的WEB应用程序注入攻击详细介绍
- 基于SQL Server的WEB应用程序注入攻击详细介绍
- ArcGIS Server 9.2实现基于web浏览器的在线编辑
- 《基于DE2的嵌入式WEB-SERVER研究》(网络工程)
- C++细节(二):区分数据的类型
- [linux]linux命令的后台不挂断运行
- redis cluster高可用集群部署详解
- 亿级Web系统搭建:单机到分布式集群
- ETL 数据加载机制概述
- 基于IOLoop的Web Server
- 关于web项目部署到云平台上get方式进行参数传输是中文乱码的问题
- thermal中cool device和zone device的绑定
- SDUT 3376 数据结构实验之查找四:二分查找
- 过拟合问题
- 水平权限漏洞的修复方案
- tp中一个字段符合多个条件的查询,where like or
- TCP三次握手分析、http登录密码抓取
- python使用tesseract-ocr完成验证码识别