图片转在自:http://www.javashuo.com/article/p-pwibfvqu-d.htmlhtml
图片转在自:http://www.javashuo.com/article/p-pwibfvqu-d.htmlpython
图片转在自:http://www.javashuo.com/article/p-pwibfvqu-d.htmlweb
接下来学习tornado数据库
http://shouce.jb51.net/tornado/ch1.html#ch1-1-1 //学习网址浏览器
我是直接用得pycharm装上就好 app
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()curl
halloword的的代码 函数
代码解读://这里来自教程tornado
编写一个Tornado应用中最多的工做是定义类继承Tornado的RequestHandler类。在这个例子中,咱们建立了一个简单的应用,在给定的端口监听请求,并在根目录("/")响应请求。oop
你能够在命令行里尝试运行这个程序以测试输出:
$ python hello.py --port=8000
如今你能够在浏览器中打开http://localhost:8000,或者打开另外一个终端窗口使用curl测试咱们的应用:
$ curl http://localhost:8000/
Hello, friendly user!
$ curl http://localhost:8000/?greeting=Salutations
Salutations, friendly user!
让咱们把这个例子分红小块,逐步分析它们:
import tornado.httpserver
import tornado.ioloop
import tornado.options
import tornado.web
在程序的最顶部,咱们导入了一些Tornado模块。虽然Tornado还有另一些有用的模块,但在这个例子中咱们必须至少包含这四个模块。
from tornado.options import define, options
define("port", default=8000, help="run on the given port", type=int)
Tornado包括了一个有用的模块(tornado.options)来从命令行中读取设置。咱们在这里使用这个模块指定咱们的应用监听HTTP请求的端口。它的工做流程以下:若是一个与define语句中同名的设置在命令行中被给出,那么它将成为全局options的一个属性。若是用户运行程序时使用了--help
选项,程序将打印出全部你定义的选项以及你在define函数的help参数中指定的文本。若是用户没有为这个选项指定值,则使用default的值进行代替。Tornado使用type参数进行基本的参数类型验证,当不合适的类型被给出时抛出一个异常。所以,咱们容许一个整数的port参数做为options.port来访问程序。若是用户没有指定值,则默认为8000。
class IndexHandler(tornado.web.RequestHandler):
def get(self):
greeting = self.get_argument('greeting', 'Hello')
self.write(greeting + ', friendly user!')
这是Tornado的请求处理函数类。当处理一个请求时,Tornado将这个类实例化,并调用与HTTP请求方法所对应的方法。在这个例子中,咱们只定义了一个get方法,也就是说这个处理函数将对HTTP的GET请求做出响应。咱们稍后将看到实现不止一个HTTP方法的处理函数。
greeting = self.get_argument('greeting', 'Hello')
Tornado的RequestHandler类有一系列有用的内建方法,包括get_argument,咱们在这里从一个查询字符串中取得参数greeting的值。(若是这个参数没有出如今查询字符串中,Tornado将使用get_argument的第二个参数做为默认值。)
self.write(greeting + ', friendly user!')
RequestHandler的另外一个有用的方法是write,它以一个字符串做为函数的参数,并将其写入到HTTP响应中。在这里,咱们使用请求中greeting参数提供的值插入到greeting中,并写回到响应中。
if __name__ == "__main__":
tornado.options.parse_command_line()
app = tornado.web.Application(handlers=[(r"/", IndexHandler)])
这是真正使得Tornado运转起来的语句。首先,咱们使用Tornado的options模块来解析命令行。而后咱们建立了一个Tornado的Application类的实例。传递给Application类__init__方法的最重要的参数是handlers。它告诉Tornado应该用哪一个类来响应请求。立刻咱们讲解更多相关知识。
http_server = tornado.httpserver.HTTPServer(app)
http_server.listen(options.port)
tornado.ioloop.IOLoop.instance().start()
从这里开始的代码将会被反复使用:一旦Application对象被建立,咱们能够将其传递给Tornado的HTTPServer对象,而后使用咱们在命令行指定的端口进行监听(经过options对象取出。)最后,在程序准备好接收HTTP请求后,咱们建立一个Tornado的IOLoop的实例。
而后这里发现 运行事后 状态码会在运行框返回,这是在监听并返回结果
上面说的哪一个教程网站有详细的教程,这里我只记下我本身以为重要的东西,
###表单和模板
在html页面中若是要填充代码或者是参数,在html代码中添加{{}}符号 ,教程中2.1例子很重要。
在{{}}里面不只能够添加变量还能够添加表达式
{% %}中间添加控制语句 if for while try
Eg://这里取自上面哪一个网页教程
你一样能够在Tornado模板中使用Python条件和循环语句。控制语句以{%和%}包围,并以相似下面的形式被使用:
{% if page is None %}
或
{% if len(entries) == 3 %}
控制语句的大部分就像对应的Python语句同样工做,支持if、for、while和try。在这些状况下,语句块以{%开始,并以%}结束。
因此这个模板:
<html>
<head>
<title>{{ title }}</title>
</head>
<body>
<h1>{{ header }}</h1>
<ul>
{% for book in books %}
<li>{{ book }}</li>
{% end %}
</ul>
</body>
</html>
当被下面这个处理函数调用时:
class BookHandler(tornado.web.RequestHandler):
def get(self):
self.render(
"book.html",
title="Home Page",
header="Books that are great",
books=[
"Learning Python",
"Programming Collective Intelligence",
"Restful Web Services"
]
)
将会渲染获得下面的输出:
<html>
<head>
<title>Home Page</title>
</head>
<body>
<h1>Books that are great</h1>
<ul>
<li>Learning Python</li>
<li>Programming Collective Intelligence</li>
<li>Restful Web Services</li>
</ul>
</body>
</html>
###数据库 教程里用的是pymongo