AOP原理及在架构设计中的应用(二)
【摘要】 面向方面的编程(AOP)技术已在Java领域产生多年,它为传统的编程模式带来了一种新的思维和方式。AOP本身为程序结构带来的灵活性,在JavaEE架构设计上也能发挥极大的作用。本文对AOP原理,Spring AOP基本编码方式进行了简明,清晰的介绍,还对公司项目实践中AOP的基本应用模式进行了归纳,整理, 有更贴近实践的指导意义。
【关键词】AOP JavaEE 架构设计
1.3.4. 拦截器串
通常,系统关注的功能有很多,例如:日志,事务,缓存等等,因此,实际系统中,通常是多个拦截器同时工作,形成一个拦截器串,各自关注相应特定的功能。
拦截器串协同工作的基本方式为
1)串行执行,即几个拦截器,按顺序依次执行。
但在有些系统中还存在特殊需求:
2) 忽略执行
在某些情况下,例如:sayHello的参数是“Admin”时,不记录日志,只开启事务和缓存功能, 那么Log拦截器的日志记录功能需要被忽略。这种情况通常在LogAdvisor内部,对参数进行判断来实现。
public class LogAdvisor extends MethodBeforeAdvice { private static Log log = LogFactory.getLog(LogAdvisor.class); public void before(Method method, Object[] args, Object target) throws Throwable { if(“Admin”.equals(args[0])) if(log.isDebugEnabled()) log.debug("记录日志(前):" + target +", 方法:" + method.getName()); } |
3) 跳出执行
public class SecurityInterceptor implements MethodInterceptor { public Object intercept(Object obj, Method method, Object[] args, MethodProxy proxy) throws Throwable { if(“Admin”.equals(args[0])) return “管理员,你好!”;//实际执行方法 else return proxy.invokeSuper( obj , args); } } |
在某些情况下,要求终止被拦截的方法的实际执行,不再继续执行下一拦截器,而直接返回特定的结果,例如:sayHello的参数是“Admin”时,让该方法返回固定的值“管理员,你好!”。
1.3.5. AOP适用的方面
由于AOP技术本身的插件式特点,采用这种机制进行系统设计和程序开发能够为软件带来极大的灵活性和扩展性。目前,运用AOP对系统进行功能扩展主要关注的方面是:
Transactions 事务,例如Spring就利用AOP提供了通用性的事务管理器。
Logging, 日志,还包括Tracing等;
Profiling and Monitoring 性能分析和监控。
Authentication 权限,包括鉴权,安全控制等;
Caching 缓存,
Error handling 错误处理
Lazy loading 懒加载
Debugging 调试
Performance optimization 性能优化
等等。
2. 架构设计中AOP的运用
2.1. 运用方式
架构采用了JavaEE规范中经典的三层架构:表示层、业务层、持久层,如下图所示:
与一般的JavaEE架构不同, 该架构通过Factory模式在各层之前进行搭桥,通过对应的Factory类来创建下层对象。
工厂机制运用了Spring AOP技术,上层对象在请求下层资源时,可以通过代理机制切入若干功能,使得可以灵活扩展系统功能,而又使各层着重关注本职核心功能。值得注意的是,表示层采用的是Struts2框架,而它本身就是基于AOP原理进行设计的。如下图所示:
由于运用了Spring AOP技术,方面(Aspect)的开发就变成拦截器(Spring称为Advisor)的开发。该架构将Spring AOP规范定义的before,after,throwing三个阶段,和CGLib定义的invoke阶段整合为了一个抽象类: AbstractAdvisor, 方便设计人员开发新的拦截器。
并且Spring通过AOP机制已经提供通用的事务(Transaction)控制,调试(Debug),类加载分析,并发控制,简单的性能监控等基础性功能。