什么是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 = 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)MyFirst\controllers\default.py如下: def contacts(): return dict(records=db().select(db.contacts.ALL)) 5)MyFirst\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就可以使用管理界面来操作数据库。
三 web2py应用的目录结构
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下的模块。
完! |
|