首页 | 新闻 | 交流 | 问吧 | 文档 | 手册 | 下载 | 博客

python26web[web2py与MVC]

作者:  时间: 2011-04-16

 

什么是web2py,请看:python26web[web2py之helloworld] 

 

一 web2py与MVC

web2py鼓励开发人员将data representation (the model), data presentation (the view) and the application workflow (the controller)分离. 在web2py中一个典型的request流程如下图:

 

在上图中:

1) server可以是web2py内置的server,或者是第三方的server,例如Apache。server使用多线程来处理请求;

2) main是指主要的WSGI应用程序。它执行所有的通用任务和包装用户应用。它处理cookies,sessions,transactions,URL routing and reverse routing, and dispatching.

 

web2py也能够服务和处理静态文件如果web server没有处理。

1)Models,Views和Controller组件构成了用户的应用;

2)多个应用可以被寄宿在同一个web2py实例中;

3)虚线箭头代表了与数据库的通信。可以通过纯SQL或web2py的Database Abstraction Layer(DAL)来执行数据库操作,但是推荐使用DAL来保持数据库的操作独立于特定的数据库类型;

4)分发器将request的URL转化为controller中的函数调用。函数的输出可以是字符串或dictionary字典。在dictionary中的数据将被view渲染。如果用户request请求的是HTML页面(默认地为HTML),dictionary将被渲染为HTML,如果用户request请求的是XML页面,则web2py将查询与XML对应的view,将dictionary渲染为XML。开发人员可以创建相应的view来将页面渲染为任意支持的类型 (HTML, XML, JSON, RSS, CSV, RTF),此外开发人员可以自定义其他的协议来渲染为其他类型的页面。

5)所有的调用将会在transaction事务中完成,如果有任何未捕获的异常发生,此transaction将被rollback。如果request执行成功,transaction将被commit。

6)web2py自动地处理sessions和session cookies,当transaction被commit,对应的session也被存储,除非用户显式的制定放弃存储。

7)web2py支持在指定的时间或某些指定的动作完成后并行的执行指定的任务。通过此方式,可以实现在后台运行耗时的任务,不至于影响用户体验。

 

二 web2py中MVC的实例

1) 在web2py的管理页面中http://127.0.0.1:8000/admin/default/site,新建简单应用(New simple application)来创建简单应用MyFirst。此时MyFirst其实是对welcome的拷贝。

2)修改modue,view和controller如下:

3)modules下的db.py如下:

db = DAL('sqlite://storage.sqlite')db.define_table('contacts',   Field('name'),   Field('phone'))
db.contacts.insert(name
="itech",phone='123')
db.contacts.insert(name
='AAA',phone='456')
db.contacts.insert(name
='BBB', phone='789'

4)controllers下的default.py如下:

def contacts():     
  
return dict(records=db().select(db.contacts.ALL))

5)views下的default/contacts.html如下:

<h1>Records</h1>
{{
for record in records:}}
{{
=record.name}}: 
{{
=record.phone}}<br />{{pass}} 

6)运行http://127.0.0.1:8000/MyFirst/default/contacts.html如下:

 

注意:正式项目中表中插入记录不应该在db.py中,这里只是演示。在正式的项目中保留appadmin.py,appadmin.html就可以使用管理界面来操作数据库。

 

完!