什么是web2py,请看:python26web[web2py之helloworld]
一 web2py与MVC
web2py鼓励开发人员将data representation (the model), data presentation (the view) and the application workflow (the controller)分离. web2py的主要设计思想就是MVC,在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)MyFirst\modules\db.py如下:
db.contacts.insert(name="itech",phone='123')
db.contacts.insert(name='AAA',phone='456')
db.contacts.insert(name='BBB', phone='789')
4)MyFirst\controllers\default.py如下:
return dict(records=db().select(db.contacts.ALL))
5)MyFirst\views\default\contacts.html如下:
{{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就可以使用管理界面来操作数据库。
三 web2py应用的目录结构
1)Models 描述了数据的表现,包括数据库table和table间关系;
2)controllers 描述了应用的逻辑和工作流;
3)views 描述了如何使用HTML和JavaScript将数据的呈现给用户;
4)languages 描述了如何翻译应用中的字符串到支持的各种语言;
5)static files 不需要处理(例如images,css stylesheets,等);
6)ABOUT和README 自解释文档;
7)errors 存储了应用产生的错误报告;
8)sessions 存储了跟特定用户相关的信息;
9)databases 存储了SQLite数据库和其他相关的表信息;
10)cache 存储了缓存的应用的部分;
11)modules 存储了应用所引用的其他的python模块;
12)private 存储了只可以被controller访问的文件;
13)uploads 存储了只可以被models访问的文件;
14)tests 存储了testing相关的脚本;
Models,views,controllers,languages和static文件可以通过web administration界面来访问。ABOUT,README和errors也可以通过web administration界面的菜单来访问。Sessions,cache,modules,private和uploads只能被应用访问,不能通过web administration界面访问。
web2py的应用目录如下:
__init__.py ABOUT LICENSE models views
controllers modules private tests cron
cache errors upload sessions static
其中__init__.py是一个空文件,用来使python能够导入modules下的模块。
完!