使用Agavi进行MVC编程简介,第1部分:使用Agavi开辟一个新世界
:
Agavi将生成必要的类文件,并将它们放到正确的位置。 步骤2:定义路由 当该过程完成时,重新访问 $WASP_ROOT/app/routing.xml文件,并为引用新创建的操作的静态内容添加一个基路由,如清单12 所示: 清单12. Default/StaticContent 路由定义
这个路由比前面见到的要复杂一些。首先,它包含一个 “name”属性;这提供一个手动生成路由(随后就会看到)时可以使用的标签。其次,正则表达式将以以下格式之一匹配 URL:
很明显,上面例子中的最后部分是变量。必须通过将该部分的路由定义包含在圆括号中,将相关信息告诉 Agavi的路由子系统。使用圆括号创建了 Agavi 手册中的捕捉组(apture group)。捕捉组可用于自动地将URL的特定部分转换为Agavi变量,这些变量最终需要经过验证并放到一个 AgaviRequestDataHolder 对象中,然后从操作或视图的内部访问它们。 步骤3:定义验证规则 然而,用捕捉组定义路由仅完成了一半工作。路由中的变量要进入操作或视图中,必须经过Agavi的极其严格的输入验证过滤器。默认情况下,这个过滤器设置为最严格的级别;这意味着它不认识(或不能通过特定的验证测试)的任何 GET或POST变量都被自动删除,并且再也不能进入应用程序。这种异常严格的输入检查策略是Agavi应用程序如此安全的原因之一。 Agavi 自带有大量内置输入验证器,并且可以通过简单的XML文件配置它们。输入验证器与它所属的操作同名,并且可以在模块的validate/目录中找到。要查看 StaticContentAction 验证器,需要在$WASP_ROOT/app/modules/Default/validate/StaticContent.xml 上编辑该文件,并使用清单13 中的XML 填充它: 清单13. Default/StaticContent Action定义
|
凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢! |