web.py 是一个python 的web 框架,它简单而且功能强大。web.py 是公开的,无论用于什么用途都是没有限制的。
先让大家感受一下web.py 的简单而强大:
看看,上面就是一个基于web.py 的完整的web 应用。不信?!将上面的代码保存为文件code.py,在命令行下执行python
code.py。然后打开你的浏览器,打开地址:http://localhost:8080/rosswan,看看结
果 :)没有意外的话(当然要先安装web.py,下面会有介绍),浏览器会显示“hello, rosswan!”。这是一个最简单的hello
world web 应用。是不是很简单?!下面将较为详细地介绍下web.py 。find fun :)
1. 安装
setup.py install,在linux 等系统下,需要root 的权限,可以执行:sudo python setup.py install。
安装完毕之后,就可以正式开始web.py 之旅…
2. url 处理
在每个web.py 应用,必须先import web 模块:
现在,我们须要告诉web.py url 如何组织,让我们以一个简单例子开始:
在上面的例子中,第一部分(‘/’)是一个匹配url 的正则表达式,像/,/help/faq,/item/(\d+),等等;第二部分(‘index’)是一个类名,匹配的请求将会被发送过去。
现在,我们需要编写index 类。当大部人浏览网页的时候,他们都没有注意到,浏览器是通过http 跟world wide web 通信的。通信的细节不太重要,但要明白一点,用户是通过urls(例如 / 或者 /foo?f=1)来请求web 服务器完成一定请求的(例如 get 或者post)。
get 是最普遍的方法,用来请求一个页面。当我们在浏览器里输入“harvard.edu” 的时候,实际上它是向web 服务器请求get ”/“。另一个常见的方法是post,常用于提交特定类型的表单,例如利用信用卡付费和处理一个订单。注意,get urls 能够被搜索引擎索引得到(想像一下google 尝试购买你网站上的所用物品)。
在我们的web.py 代码中。我们清晰区分这两种方法:
当接收到一个get 请求时,上面的get 方法将会被web.py 调用。
好的。现在,我们只需添加最后一行代码,让web.py 启动网页应用:
上面告诉web.py 如何配置urls,以及找寻的类在文件中的全局命名空间。
整个code.py 文件的内容如下:
注意到没有,虽然我说了很多东西,但实际上web 应用的代码就只得上面的几行,而且这是一个完整的web.py 应用。在你的命令行下输入:
现在,你的web.py 应用已经启动了服务器。通过浏览器访问http://localhost:8080/ 的话,会见到”hello,
world!“。在启动服务器的时候,你可以在python code.py 后面添加ip
地址/端口 来控制web.py 启动的服务器。例如:python code.py 8888。
3. 调试
web.py 本身也提供调试的工具。在最后的“if name …” 代码前面添加:
并在最后的“if
name …” 添加”web.reloader“:
上面的代码会使你在调试的阶段得到更多有用的信息。web.reloader 其实是一个中间件,当你在运行时修改了code.py 文件后,web.reloader 会重新加载code.py 文件,让你在浏览器上立刻可以看到变化。如何有多何变化的话,还是需要重新启动服务器。web.py
也提供web.profiler ,可以输出有用的信息,有关每个页面的每个函数调用的次数,这用助于你改善代码。
4. 模板
在python 里面编写html 代码是相当累赘的,而在html 里嵌入python 代码则有趣得多。幸运地,web.py 使这过程变得相当容易。
在我们的web 应用里,添加一个新的文件夹用来组织模板文件(例如”/templates“)。然后再新建一个html 文件(例如:”index.html“):
或者,你可以用web.py 的模板语言用编写这个html 文件:
注意上面代码的缩进!
正如你所见的,上面的模板看上去跟这python 文件很相似,以def with 语句开始,但在关键字前需要添加”$“。
注意:在模板内的变量,如果包含有html 标记,以$ 方式引用变量的话,html 标记只会以纯文本的显示出来。要想html 标记产生效果,可以用$: 引用变量。
现在,回到code.py 文件,在”import web” 的下一行添加:
这告诉web.py 在哪里可以搜索得到模板目录。
提示:可在render 调用里添加cache = false 使得每次访问页面时都重载模板。
下面继续修改code.py 文件的get 方法:
上面的”index“ 是模板的名字,”name“ 是传递过去的参数。
修改code.py 文件的urls 变量:
上面的“/(.*)” 是一个正则表达式。
再将get 方法修改如下:
现在,访问”/“的话,会显示”hello, world!“;访问”/joe“ 的话,会显示”i
just want to say hello to joe“。
5. 数据库
添加以下代码,则可以正确配置你的数据库:
现在,先行在数据库里创建一个简单的表:
初始化一行:
回到code.py,修改get 方法如下:
修改urls 变量:
重新编辑index.html 文件如下:
现在,可以访问”/“,如果显示”learn web.py“,则祝贺你成功了!
现在,再让我们看看如何向数据库写入。
在index.html 文件的尾部添加如下内容:
修改code.py 文件的urls 变量如下:
在code.py 里添加一个类:
web.input 使你能够方便地访问用户通过表单提交上来的变量。web.insert 用于向数据库的 “todo” 表插入数据,并且返回新插入行的id。web.seeother 用于重转向到”/“。
提示:对于数据库的操作,还有web.transact(), web.commit(), web.rollback(),web.update()。
在web.py 里,还有web.input,web.query 和其它的函数,返回”storage objects”,可以像字典型类(dictionaries) 的使用。
6. 总结
这篇教程到这里也要结束了,如果你对web.py 有兴趣,可以搜索更多关于web.py 的文档看看,你一定会发现更酷的东西。have fun!