import tornado.httpserver
import tornado.ioloop
import tornado.options
import tornado.web
from tornado.options import define, options
define("port", default=8000, help="run on the given port", type=int)
class IndexHandler(tornado.web.RequestHandler):
def get(self):
greeting = self.get_argument('greeting', 'Hello')
self.write(greeting + ', friendly user!')
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()
分步解析
from tornado.options import define, options
define("port", default=8000, help="run on the given port", type=int)
tornado.options
- tornado.options:从命令行中读取设置,可以使用这个模块指定我们的应用监听HTTP请求的端口。
- 工作流程:如果一个与define语句中同名的设置在命令行中被给出,那么它将成为全局options的一个属性。如果用户运行程序时使用了–help选项,程序将打印出所有你定义的选项以及你在define函数的help参数中指定的文本。如果用户没有为这个选项指定值,则使用default的值进行代替。Tornado使用type参数进行基本的参数类型验证,当不合适的类型被给出时抛出一个异常。因此,我们允许一个整数的port参数作为options.port来访问程序。如果用户没有指定值,则默认为8000。
RequestHandler
class IndexHandler(tornado.web.RequestHandler):
def get(self):
greeting = self.get_argument('greeting', 'Hello') //取出请求中的greeting的值,没有则用第二个参数作为默认值
self.write(greeting + ', friendly user!') //write中返回响应的内容
- 这是Tornado的请求处理函数类。当处理一个请求时,Tornado将这个类实例化,并调用与HTTP请求方法所对应的方法。
- RequestHandler类有一系列有用的内建方法,包括get_argument,可以从一个查询字符串中取得参数greeting的值。(如果这个参数没有出现在查询字符串中,Tornado将使用get_argument的第二个参数作为默认值。)
- write:以一个字符串作为函数的参数,并将其写入到HTTP响应中。
main函数解释
if __name__ == "__main__":
tornado.options.parse_command_line() //options模块来解析命令行
app = tornado.web.Application(handlers=[(r"/", IndexHandler)]) //创建Application类的实例,传递给Application类最重要的参数是handlers,告诉Tornado应该用哪个类来响应请求
http_server = tornado.httpserver.HTTPServer(app) //将Application传递给Tornado的HTTPServer对象
http_server.listen(options.port) //监听端口
tornado.ioloop.IOLoop.instance().start() //在程序准备好接收HTTP请求后,我们创建一个Tornado的IOLoop的实例