业务层模式:
业务代表:Business Delegate。封装对业务服务的访问,隐藏服务层具体实现细节,主要为降低客户端和服务层之间的耦合。除了隐藏服务细节、处理服务异常等基础功能以外,还可以做服务的缓存。业务代表是客户端的直接客户,起到客户端业务抽象层的作用,而业务代表的另一头,常常连接着会话门面。
比较常用的情况就是在某种远程连接和业务处理的基础上,使用业务代表把这些细节统统包装起来,给内部提供的模型也好API也好,都是和外部接口相异的。比如一个系统中对于展现的内容数据的同步,以及订购、使用等业务流程,都由SOAP消息载体来协助完成,那么封装起SOAP消息这种底层行为的PCMP模块,对其上内部组件暴露的都是系统中通用的模型和API,将SOAP定义的模型和相应的同步、校验和通知行为等隔离开了。
服务定位器:Service Locator。封装对服务和组件的寻址。在系统,尤其是分布式系统中,服务通常被设置为可插接的,通过某种方式挂在服务总线上,寻求某服务的行为应当对服务的使用者来说透明。
某个大型解决方案中,某一组件充当SOA中的ESB,承担了服务定位的角色,派发往各个服务不同协议的请求,皆可以统一的协议收拢到该组件中,再由该组件负责以各种方式分发给不同的服务。
会话门面:Session Facade。目的有二:控制客户端对业务对象的访问;降低客户端和细粒度业务组件访问的网络负载。只暴露必要的、粗粒度的服务,并且可以对之在门面内部做好事务、安全、寻址和记录等等切面辅助工作。
多数情况下使用无状态的会话门面,对于客户端要求也较低,通常只需要单次调用就能完成功能;但也可能需要使用有状态的会话门面,通常比较复杂,需要涉及会话事务、会话资源的管理和释放。
和业务代表的关系:业务代表在客户端提供了对会话门面的抽象,把客户端的请求分别代理给专门提供特定服务的会话门面。
应用服务:集中、聚合特定功能,提供一个统一的服务层,其接口粒度比服务门面细。服务门面通常包括很少,甚至不包括业务逻辑,仅仅提供一个简单和粗粒度的接口。而一些相关的操作,之间具有内聚性,这就需要某个角色把它们聚合起来。
Facade成为粗粒度的门面的时候,内部就由多个细粒度的Service组成,这就是会话门面和应用服务之间的关系。举一个更具体的例子,一个短信息发送的会话门面,提供了消息发送的一系列功能,内部则包含了若干个应用服务:拼装消息报文、消息事务信息持久化、发送消息。合理地分割和规划应用服务是降低会话门面复杂度的有效途径。
文章系本人原创,转载请注明作者和出处
分享到:
相关推荐
《J2EE核心模式(Core J2EE Patterns)》是一本深度探讨J2EE平台设计模式的权威著作,由SUN公司的资深工程师倾力撰写。这本书是Java企业级开发者的必备参考书籍,它揭示了在复杂的企业级应用开发中,如何有效地利用...
本书讲解使用J2EE核心技术实现企业应用过程中的模式、最佳实践、设计策略以及经过验证的解决方案,涵盖了JSP、servlet、EJB、JMS等技术,其中J2EE模式目录包括21个模式以及大量策略,帮助读者迅速熟练掌握J2EE技术...
《J2EE Core Design Patterns》是一本专注于Java企业级应用开发中的核心设计模式的重要书籍。设计模式是软件工程中经过实践验证的、解决特定问题的模板,尤其在复杂如J2EE(Java 2 Platform, Enterprise Edition)...
### J2EE核心模式——最佳实践与设计策略 #### 一、引言 《J2EE核心模式:最佳实践与设计策略》是一本由Deepak Alur、John Crupi和Dan Malks编写的权威指南,它深入探讨了Java 2 Enterprise Edition(J2EE)平台下...
《Core J2EE Patterns》是Java企业级应用开发的经典之作,它详细介绍了在J2EE平台上构建可扩展、高效、可维护的系统所使用的最佳实践和设计模式。这本书的第二版源码对于深入理解J2EE开发中的核心概念和技术具有极高...
在研究多种J2EE Web框架和J2EE核心模式的基础上,提出了一种基于J2EE核心模式的组合Web框架--CWFBP(Composite Web Framework based on core J2EE Patterns)模型.框架采用分层体系架构,集成了开源的J2EE Web框架和持久...
《核心的J2EE设计模式》是一本专为Java企业级开发者编写的经典著作,它深入探讨了在J2EE平台上构建可扩展、高效且可维护的系统所使用的最佳实践和设计模式。这本书的第二版进一步更新了内容,以适应不断演进的Java...
Core J2EE Patterns
二、J2EE核心模式 1. **单例模式**:在J2EE环境中,单例模式常用于创建全局唯一的服务器端组件,例如应用配置对象或事务管理器。 2. **工厂模式**:用于动态地创建对象,特别是在需要依赖注入或需要隔离具体实现时...
《J2EE核心模式》源代码解析 J2EE(Java 2 Platform, Enterprise Edition)是Java平台上用于构建企业级应用程序的框架。它提供了一组服务、APIs和协议,以支持开发分布式、多层的企业应用。《J2EE Core Patterns》...
通过学习和应用这些J2EE核心模式,开发者能够更高效地构建可扩展、可维护的企业级应用。例如,EJB.Design.Patterns.Chinese.eBook-YSSY这个文件很可能是这本书的中文电子版,里面详细解释了上述各种模式的实现细节和...
《SUN - Core J2EE patterns》不仅是一本关于J2EE模式的指南,更是一本实用的开发手册,它涵盖了从理论到实践的全过程,对任何希望深入了解J2EE架构并掌握其核心模式的开发者来说,都是一本不可或缺的参考书籍。...
通过学习《Core J2EE Patterns》第二版,开发者可以掌握J2EE开发的核心概念和技术,提升在大型企业级项目中的设计和实现能力。这本书对于想要深入了解J2EE平台和构建高质量企业应用的开发者来说,是一本不可多得的...
标题《Core J2EE Patterns Best Practices And Design Strategies》和描述部分介绍了软件设计模式的重要性,将设计模式比喻为一个组织的“部落记忆”的有形体现。设计模式是解决常见问题的通用解决方案,它源自之前...
本书《J2EE Design Patterns Applied》旨在为读者提供一套全面的指南,通过实际案例深入探讨如何在J2EE环境中应用各种设计模式来解决常见问题。对于那些熟悉J2EE组件如Servlets、JSP页面和EJBs开发与部署的开发者来...
中文译名:J2EE设计模式 作者: (美)William Crawford & Jonathan Kaplan <br/>本书一边在持久化和消息通信等领域中描述一些新模式,一边向你说明如何在J2EE应用的上下文中实现许多模式。有助于考虑问题...
### Core J2EE Patterns:拦截过滤器模式 (Intercepting Filter) #### 背景与情境 在J2EE环境中,请求处理机制需要处理多种类型的客户端请求,这些请求可能涉及不同的处理逻辑。例如,某些请求可能直接转发到相应...