Tornado是一个具有强大异步功能的Python Web框架.

Hello World

使用pip安装tornado:

pip install tornado

编写控制器:

import tornado.httpserver
import tornado.ioloop
import tornado.options
from tornado.web import RequestHandler from tornado.options import define, options
define("port", default=8000, help="run on the given port", type=int) class IndexHandler(RequestHandler):
def get(self):
self.write('Hello World!') if __name__ == "__main__":
tornado.options.parse_command_line()
app = tornado.web.Application(handlers=[(r"/", IndexHandler)])
http_server = tornado.httpserver.HTTPServer(app)
http_server.listen(options.port)
tornado.ioloop.IOLoop.instance().start()

在命令行中运行:

python hello.py --port=8000

在浏览器中访问http://localhost:8000, 可以看到来自服务器的Hello World.

Web.Application

每一个torndao服务端程序均使用Application封装:

define("port", default=8000, help="run on the given port", type=int)
if __name__ == "__main__":
tornado.options.parse_command_line()
app = tornado.web.Application(handlers=[(r"/", IndexHandler)])
http_server = tornado.httpserver.HTTPServer(app)
http_server.listen(options.port)
tornado.ioloop.IOLoop.instance().start()

常量定义:

define("port", default=8000, help="run on the given port", type=int)

解析命令行参数并进行配置options:

tornado.options.parse_command_line()

Web.Application的handler关键字参数是一个列表,列表中的元素是(地址正则表达式,handler类)二元组

handlers=[(r"/", IndexHandler)]

初始化httpserver:

http_server = tornado.httpserver.HTTPServer(app)

绑定服务器监听的端口:

http_server.listen(options.port)

启动IO循环来接收请求并处理:

tornado.ioloop.IOLoop.instance().start()

RequestHandler

Tornado开发的核心是继承RequestHandler类,并重写get, post等方法实现对相应HTTP请求的响应。

返回响应

一般情况下不需要get或post方法返回任何值, 使用self.write(chunk)可以直接将块写入缓冲区, chunk参数可以是str或dict对象.

若chunk是一个dict对象, tornado会将其序列化JSON字符串同时会把响应头设置为application/json.

RequestHandler.render(template_name, **kwargs)会渲染模板并将结果返回客户端:

class PageHandler(RequestHandler):
def get(self):
self.render('./templates/index.html')

若要对渲染结果进行处理则可以使用RequestHandler.render_string(template_name, **kwargs)获得渲染结果字符串, 并在处理后手动写入缓冲区.

RequestHandler.redirect(url, permanent=False, status=None)方法可以将请求重定向到其它url.

如果指定了status参数, 这个值将作为HTTP状态码; 否则,将通过 permanent 参数选择301 (永久) 或者 302 (临时). 默认是 302 (临时重定向).

RequestHandler.set_status(status_code, reason=None)方法可以设置响应的状态码, reason参数用人类可读的原因短语来描述状态码. 如果reason是None, 会自动使用httplib.responses 的reason.

RequestHandler.set_header(name, value)add_header(name, value)可以设置或添加响应头中的参数.

RequestHandler.flush(callback=None)刷新缓冲区然后执行回调.

RequestHandler.finish(chunk=None)将返回response并断开连接, 一般在响应方法退出时自动执行.

获得请求参数

get和post方法默认只有一个self参数, 而url中被匹配的字符串会被作为位置参数传入:

handlers = [("user/([0-9]+)", UserInfoHandler)]

class UserInfoHandler(Requesthandler):
def get(self, uid):
self.write(str(uid))

RequestHandler.get_body_argument(name)可以返回请求body部分中的参数,比如post方法提交的参数,.

RequestHandler.get_query_argument(name)可以获得包含url中的参数, 一般为get方法提交的参数.

RequestHandler.get_argument(name)则可以获得body或query参数.

class LoginHandler(RequestHandler):
def post(self):
username = self.get_argument('username')
password = self.get_argument('password')
result = do_login(username, password)
self.write(result)

RequestHandler.request 对象封装HTTP请求的信息, request.arguments以字典的形式包含了所有body和query参数.

request.headers.get(name, default=None)则可以用来获得在请求头中的参数.

request.files可以获得上传文件的信息, 先编写上传表单:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Upload</title>
</head>
<body>
<form action="/do-upload/" method="post" enctype="multipart/form-data">
<input type="file" name="filename">
<input type="submit" value="submit">
</form>
</body>
</html>

实现handler:

class UploadFileHandler(RequestHandler):
def post(self):
upload_path = os.path.join(os.path.dirname(__file__),'files')
filemeta = self.request.files['filename'][0]
filename = filemeta['filename']
path = os.path.join(upload_path, filename)
with open(filepath,'wb') as fw:
fw.write(meta['body'])
self.write('upload success')

cookie

RequestHandler.cookies 存储cookie的字典, 等同于self.request.cookies.

RequestHandler.get_cookie(name, default=None) 获取给定name的cookie值, 如果未获取到则返回默认值.

RequestHandler.set_cookie(name, value)设置给定的cookie 名称/值还有其他给定的选项.

RequestHandler.clear_cookie(name, path='/', domain=None)删除给定名称的cookie.受cookie协议的限制,必须传递path和domain来清除这个cookie.

RequestHandler.clear_all_cookies(path='/', domain=None)删除用户在本次请求中所有携带的cookie.

tornado的cookie系统同样提供了含有数字签名的时间戳的secure_cookie系统.其操作与普通cookie类似:

class AuthHandler(RequestHandler):
def get(self, redirect_uri):
uid = self.get_secure_cookie('uid')
token = make_token(uid)
self.set_secure_cookie('token', token)
self.redirect("/" + redirect_uri)

参考资料:

Tornado简介的更多相关文章

  1. Python Tornado简介

    简介 Tornado 是 FriendFeed 使用的可扩展的非阻塞式 web 服务器及其相关工具的开源版本.这个 Web 框架看起来有些像web.py 或者 Google 的 webapp,不过为了 ...

  2. 01-tornado学习笔记-Tornado简介

    01-Tornado简介   Tornado是使用Python编写的一个强大的.可扩展的Web服务器.它在处理严峻的网络流量时表现得足够强健,但却在创建和编写时有着足够的轻量级,并能够被用在大量的应用 ...

  3. 01-tornado练习-tornado简介

    # coding = utf-8 """ 启动一个tornado的web服务 """ import tornado.web from tor ...

  4. tornado web 框架的认识

    tornado 简介 1,概述 Tornado就是我们在 FriendFeed 的 Web 服务器及其常用工具的开源版本.Tornado 和现在的主流 Web 服务器框架(包括大多数 Python 的 ...

  5. 浅析tornado web框架

    tornado简介 1.tornado概述 Tornado就是我们在 FriendFeed 的 Web 服务器及其常用工具的开源版本.Tornado 和现在的主流 Web 服务器框架(包括大多数 Py ...

  6. tornado web框架

    tornado web框架 tornado简介 1.tornado概述 Tornado就是我们在 FriendFeed 的 Web 服务器及其常用工具的开源版本.Tornado 和现在的主流 Web ...

  7. Tornado基本应用

    Tornado简介 Tornado有自己的socket(异步非阻塞,原生支持WebSocket),Django没有. Tornado的模板语言更接近Python风格,比Django要好理解. Demo ...

  8. Python之tornado

    一.快速了解Tornado框架 1)tornado简介 Tornado 和现在的主流 Web 服务器框架(包括大多数 Python 的框架)有着明显的区别:它是非阻塞式服务器,而且速度相当快.得利于其 ...

  9. 20-2 树莓派搭建服务器 Tornado Web服务器

    Drive.google.com/drive/folders/1ahbeoEHkjxoo4NV1wReOmpoRWbl448z- 1.Tornado简介 Tornado一款使用 Python 编写的, ...

随机推荐

  1. 译:Microsoft/ReactXP 简介

    在Github的Microsoft项目中发现一个名为ReactXP的项目,这是一个由Skype团队开发的,用于进行Web及跨平台APP开发的库(建立在React Js 和 ReactNative之上) ...

  2. Android开发消除横向排列的多个Button之间的空隙

    一.问题重述 摘要里描述的可能不太清楚,问题如下图: 如何消除Button1和Button2之间的空隙,以及Button与左右边界之间的空隙? 二.问题根源 这里出现的空隙其实是Button的背景图片 ...

  3. .net core2.0 codefirst 创建数据库的问题!

    appsettings.json和Startup.cs就不记录了,网上很多!! 1.必须在有DbContext类的项目里添加这3个NuGet引用 Microsoft.EntityFrameworkCo ...

  4. spring jdbc批量插入

    http://blog.csdn.net/fyqcdbdx/article/details/7366439

  5. Socket编程入门

      socket基本知识 网络上的两个程序通过一个双向的通信连接实现数据的交换,这个连接的一端称为一个socket. 建立网络通信连接至少要一对端口号(socket).socket本质是编程接口(AP ...

  6. Mysql分析-profile详解

    一.前言当我们要对某一条sql的性能进行分析时,可以使用它. Profiling是从 mysql5.0.3版本以后才开放的.启动profile之后,所有查询包括错误的语句都会记录在内.关闭会话或者se ...

  7. 前端入门html(表单)

    day48 配置Django项目:https://blog.csdn.net/zV3e189oS5c0tSknrBCL/article/details/79606994 <!DOCTYPE ht ...

  8. Lucence工作原理

    lucence 是一个高性能的java全文检索工具包,他使用倒排序文件索引结构,改结构和相应的生成算法如下: 一.设有两篇文章1和2      文章1的内容为:Tom lives in guangzh ...

  9. 【bug】使用微信分享SDK,配置成功但分享信息异常

    使用微信JSD做H5分享功能时,显示配置成功,但分享出去的信息并不是配置中的信息.(p.s. ios 分享后只有一个当前的链接,androd连分享的图标都没有), 最终找的的原因是:分享的链接中,参数 ...

  10. HTML+Javascript制作拼图小游戏详解(终)

    上次我们已经讲解了制作的原理,并且展示了主要代码. 这次我将完整的代码给大家,仅供参考. HTML部分如下: <!DOCTYPE html> <html lang="en& ...