4年以前,当我还在一种叫ASP的东西上工作的时候,我整天为两个问题头疼不已:一是如何将分散的页面控制整合起来。解释型的服务器端脚本,每个页面都有接收和处理请求的能力。这样以每个页面作为独立的单元来处理请求让人感觉粒度太小,分散又不爽。二是如何减少重复代码。脚本语言里处理重复代码的灵丹妙药是include。每个页面里都可以include header,footer,session checker,屡试不爽。但有一次我很不幸,我要改一下header的名字……
后来投靠了java,用了struts,豁然开朗,就像天空中飘下来几个大字:前端控制器。在这几个字的怀里缠绵已久,回望脚本语言林林总总,处处鲜花烂漫。
前端控制器在《J2EE核心模式》一书中已经完整的定义过了了,不再复述。下面只是记一下自己在工作中遇到过的前端控制器模式的实例:
1. 解释型脚本的前端控制器的实现:近期接触了一个php项目,打开看了它的index.php,顿时感觉醍醐灌顶,赞叹作者思想精妙不已,一个小小的页面里面做了控制分发和页面Layout处理。用户所有的请求都发送给index.php页面,然后后面加上几个参数,如action和event。该系统个php文件的关系是通过命名约束来处理的。比如如果action=XXX,那么会有一个XXX.class.php,一个XXX.page.template.php,还有相关的footer,header,form,content之类的页面对应文件。当index页面接到请求的时候通过action名字匹配,利用万能的include将对应的class.php加载进来,作为对action进行处理的command使用。当command处理完以后,然后再把对应的page.template,footer,header,content加载进来,然后根据event进行处理。所有动作完成后,把组装好的页面返回给用户。一次控制分发和页面处理就完成了。一个百行的index.php代码就完成了一个完整的前端控制器,整个框架不可谓不轻啊。脚本的灵活性让我这个整天活在java的xml配置文件里的人好生羡慕啊。
更加完整的解释型前端控制器:用过一个月的ColdFusion,解释型的标签式语言。March II是这个平台上最流行的MVC框架之一。这个框架和struts非常相似,一个配置核心的XML文件。不过解释型脚本的问题在于它们的最小粒度永远都是独立的一个页面。这个框架接收用户请求的还是那个index.cfm文件。这个文件会将请求转给March II的核心文件,并且在第一次被调用的时候会初始化一个应用级的变量,来保存系统xml里的信息。然后通过index.cfm后面的参数匹配来处理action(MarchII叫它listener),event之类的东西。这个系统在实现信息包装、控制分发和页面处理的同时,还实现了拦截器的功能。在处理action的listener前面加了一个叫filter的东西来处理,来进行过滤用户信息。整体来说这个框架算是一个比较完整的MVC框架。也是我见过的比较完整的解释型脚本的框架。
2.JAVA EE里的前端控制器:Strut1和Struts2里面的做法算是比较经典的两种前端控制器。由于JAVA EE中对处理用户请求的单元进行了重新定义,类型更丰富,比如Filter和Servlet。而配置的映射机制使接收用户请求的粒度变得很有弹性。struts1里面使用Servlet作为前端控制器,来实现用户请求的封装,控制分发,和结果返回处理。struts2 对struts1这方面最大的改进莫过于使用Filter来作为前端控制器。由于Filter本身就是非常典型的Chain模式,请求运转与Filter之中,就是行走于一个链中,而且filter接收和处理请求位于比Servlet更靠前的位置,这使我们在基于它进行开发时,活动余地更大,更增强了我们对request和response的控制,也提供了一种框架内更便捷的拦截器(或者叫子链)实现方式。关于Struts1和struts2,想必大家都已经烂熟于心了,也没必要重复了。
3. 令人眼前一亮的奇妙想法:和同事交流前端控制器模式的心得,他说了一个让人神清气爽的例子,也是php的。他维护的那个项目有一个要求比较安全的模块。刚开始他始终找不到驱动这个模块的核心在哪里。用户请求的地址总是找不到相匹配的php文件,也没有找到代码里有能处理这些请求分发的地方。找来找去,突然发现这个系统的前端控制器是一个大家天天都会见的页面:
HTTP 404错误页面。因为每一个找不到对应资源的请求都会来到这里,所以他们在这里做了请求解析、控制分发的处理。看到如此巧妙的东西,实在是惊叹设计人员的脑子。且不说这种做法的好与坏,它至少将核心处理的代码隐藏到了一个应用级别以外的地方。大家大笑以后,想想这也是个很好的trick啊。
分享到:
相关推荐
在软件开发领域,设计模式是一种经过时间和实践...总的来说,前端控制器模式是iOS开发中的一个重要设计模式,它有助于创建健壮、可扩展的应用程序。通过合理地运用这种模式,开发者可以提高代码质量,提升开发效率。
前端控制器模式(Front Controller Pattern)是一种在软件工程领域广泛采用的设计模式之一,它主要用于提供一种集中的请求处理机制。在这种模式下,所有的请求都将由一个单一的处理程序进行处理。这个处理程序能够...
前端控制器设计模式旨在为处理所有传入的Web请求提供一个集中的入口点。该模式确保在Java Web应用程序中对请求进行一致且高效的路由和管理。 ## 二、详细解释及实际示例 1. **实际示例**: - 在现实世界中,酒店的...
本项目使用用JSP语言作为根本,选用经典的Tomcat作为服务器平台,采用MVC、前端控制器、服务工作者三种主要模式,并用Eclipse作为开发平台,详细介绍了本管理系统的开发过程。并从系统的需求分析、系统分析、概要设计...
2. **控制策略设计**:选择合适的PFC控制算法,编写对应的控制器代码,确保输入电流的谐波成分最小化。 3. **仿真设置**:设定合适的仿真条件,如电源电压、负载变化等,以验证AFE在各种工况下的性能。 4. **结果...
除了以上三种模式,前端设计模式还包括单例模式(确保一个类只有一个实例)、代理模式(为其他对象提供一种代理以控制对这个对象的访问)、装饰器模式(动态地给对象添加一些额外的职责)等。这些模式在实际项目中...
在前端开发中,装饰器模式常用于实现AOP(面向切面编程),比如日志记录、性能监控、权限控制等功能。通过定义装饰器函数,可以在不侵入原代码逻辑的情况下,控制代码的执行流程。例如,可以创建一个`logDecorator`...
技术决策我决定实现前端控制器模式来封装典型的请求 -> 路由 -> 调度 -> 响应周期。 我相信我可以称之为简单的 API CRUD 微框架,用于在 PHP 上创建小型服务。 音乐播放器应用分为两部分: Frontend(前端)应用程序...
本学习笔记将涵盖前端控制器、文件上传、异常处理以及开发过程中的心得小结。 1. **前端控制器(DispatcherServlet)** 前端控制器是SpringMVC的核心组件,负责接收所有HTTP请求,然后根据请求的类型和映射规则...
结合前端控制器模式,可以实现一个集中的入口点,处理所有HTTP请求,简化路由管理,提供统一的错误处理机制,以及更方便的依赖注入。 "微服务测试"是指在微服务架构中进行的测试活动。微服务架构提倡将单一应用程序...
**MVC 模型-视图-控制器**是一种软件设计模式,起源于1980年代的Xerox PARC为Smalltalk-80编程语言设计的。MVC模式被广泛应用于现代软件开发,特别是在Java、ColdFusion和PHP等平台上。它的主要目标是将应用程序的...
装饰器模式(Decorator)在不改变对象原有功能的基础上动态添加新的职责;代理模式(Proxy)为其他对象提供一种代理以控制对这个对象的访问。 3. **行为型模式**:观察者模式(Observer)定义了对象之间的一对多...
4. **装饰器模式**:装饰器模式可以在不修改对象本身的情况下动态地给对象添加新的行为或责任。在JavaScript中,类装饰器和属性装饰器可以用于增强类和其成员的功能。 5. **策略模式**:策略模式定义了一系列算法,...
在web前端开发领域,时间管理器是一个至关重要的工具,它帮助用户有效地跟踪和安排任务,提高工作效率。这个实例深入探讨了如何使用JavaScript和其他前端技术来创建一个功能齐全的时间管理器应用。 首先,...
1. MVC模式:这是一种设计模式,将应用程序分为三个主要部分:模型(Model)、视图(View)和控制器(Controller)。模型处理业务逻辑和数据,视图负责展示数据,而控制器接收用户输入并调用模型和视图来响应。 2. ...
自定义前端控制器模式实现。 对于不需要使用任何框架的小型网络应用程序。 如何使用: 使用后缀“Ctrl”在包“Controller”中创建一个新类; 实现接口IAction; 在“WebContent”文件夹中创建与Controller相关...
5. **Alpha透明度控制**:对于需要透明效果的颜色,颜色选择器会提供一个额外的通道来调整颜色的透明度,从而实现半透明效果。 6. **实时预览**:在选择颜色的同时,可以即时预览颜色在实际应用场景中的效果,便于...
《前端面试之道》是一本专为前端开发者准备的面试指南,涵盖了从基础到高级的各类前端技术知识点。这本书深入浅出地讲解了在面试中可能会遇到的问题,旨在帮助读者提升面试技巧,顺利通过面试关卡。尽管标签中提及了...
调用`Zend_Controller_Front::getInstance()`将创建并返回一个前端控制器对象,如果已经存在则直接返回该实例。 ```php $front = Zend_Controller_Front::getInstance(); ``` **2. setControllerDirectory()** 该...