IOC和AOP使用拓展 (2)

注入null和空字符串值
可以使用注入空字符串,使用

<!-- 注入空字符串值 --> <property> <value></value> </property> <!-- 注入null值 --> <property> <null/> </property> 其他增强类型

Spring支持多种增强类型,除了我们上一篇文章说的前置增强和后置增强,在这里我们在补充几种常用的增强类型

异常抛出增强

异常抛出增强的特点是在目标方法抛出异常时织入增强处理。使用异常抛出增强,可以为各功能模块提供统一的,可拨插的异常处理方案

/** * 定义包含增强方法的JavaBean */ public class ErrorLogger { private static final Logger log = Logger.getLogger(ErrorLogger.class); public void afterThrowing(JoinPoint jp, RuntimeException e) { log.error(jp.getSignature().getName() + " 方法发生异常:" + e); } }

Spring配置文件

<!-- 声明增强方法所在的Bean --> <bean></bean> <!-- 配置切面 --> <aop:config> <!-- 定义切入点 --> <aop:pointcut expression="execution(* service.UserService.*(..))" /> <!-- 引用包含增强方法的Bean --> <aop:aspect ref="theLogger"> <!-- 将afterThrowing()方法定义为异常抛出增强并引用pointcut切入点 --> <!-- 通过throwing属性指定为名为e的参数注入异常实例 --> <aop:after-throwing method="afterThrowing" pointcut-ref="pointcut" throwing="e" /> </aop:aspect> </aop:config> </beans>

expression指示符我们上一篇文章已经说话大家可以先看一下上一篇文章
使用

最终增强

最终增强的特点是无论抛出异常还是正常退出,该增强都会得到执行,类似于异常处理机制中finally块的作用,一般用于释放资源,使用最终增强,就可以为各功能模块提供统一的,可拨插的处理方案.

/** * 定义包含增强方法的JavaBean */ public class AfterLogger { private static final Logger log = Logger.getLogger(AfterLogger.class); public void afterLogger(JoinPoint jp) { log.info(jp.getSignature().getName() + " 方法结束执行。"); } }

Spring配置文件

<!-- 声明增强方法所在的Bean --> <bean></bean> <!-- 配置切面 --> <aop:config> <!-- 定义切入点 --> <aop:pointcut expression="execution(* service.UserService.*(..))" /> <!-- 引用包含增强方法的Bean --> <aop:aspect ref="theLogger"> <!-- 将afterLogger()方法定义为最终增强并引用pointcut切入点 --> <aop:after method="afterLogger" pointcut-ref="pointcut"/> </aop:aspect> </aop:config>

使用

环绕增强

环绕增强在目标方法的前后都可以织入增强处理.环绕增强是功能最强大的增强处理,Spring把目标方法的控制权全部交给它,在环绕增强处理中,可以获取或修改目标方法的参数,返回值可以对它进行异常处理,甚至可以决定目标方法是否被执行.

/** * 定义包含增强方法的JavaBean */ public class AroundLogger { private static final Logger log = Logger.getLogger(AroundLogger.class); public Object aroundLogger(ProceedingJoinPoint jp) throws Throwable { log.info("调用 " + jp.getTarget() + " 的 " + jp.getSignature().getName() + " 方法。方法入参:" + Arrays.toString(jp.getArgs())); try { Object result = jp.proceed(); log.info("调用 " + jp.getTarget() + " 的 " + jp.getSignature().getName() + " 方法。方法返回值:" + result); return result; } catch (Throwable e) { log.error(jp.getSignature().getName() + " 方法发生异常:" + e); throw e; } finally { log.info(jp.getSignature().getName() + " 方法结束执行。"); } } }

Spring配置文件

<!-- 声明增强方法所在的Bean --> <bean></bean> <!-- 配置切面 --> <aop:config> <!-- 定义切入点 --> <aop:pointcut expression="execution(* service.UserService.*(..))" /> <!-- 引用包含增强方法的Bean --> <aop:aspect ref="theLogger"> <!-- 将aroundLogger()方法定义为环绕增强并引用pointcut切入点 --> <aop:around method="aroundLogger" pointcut-ref="pointcut"/> </aop:aspect> </aop:config>

使用

增强处理类型 特 点
Before   前置增强处理,在目标方法前织入增强处理  
AfterReturning   后置增强处理,在目标方法正常执行(不出现异常)后织入增强处理  
AfterThrowing   异常增强处理,在目标方法抛出异常后织入增强处理  
After   最终增强处理,不论方法是否抛出异常,都会在目标方法最后织入增强处理  
Around   环绕增强处理,在目标方法的前后都可以织入增强处理  

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/zyjszd.html