在Spring AOP中四种常用通知类型的使用
的基础上进行修改:
bean.xml
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:aop="http://www.springframework.org/schema/aop"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/aop
http://www.springframework.org/schema/aop/spring-aop.xsd">
<!-- 配置spring的ioc,把service对象配置进来 -->
<bean id="accountService" class="com.qublog.service.impl.AccountServiceImpl"></bean>
<!-- spring中基于xml的aop配置步骤 -->
<!-- 配置Logger类 -->
<bean id="logger" class="com.qublog.utils.Logger"></bean>
<!-- 配置aop -->
<aop:config>
<!-- 配置切面 -->
<aop:aspect id="logAdvice" ref="logger">
<!-- 配置前置通知 -->
<aop:before method="beforePrintLog" pointcut-ref="pt1"></aop:before>
<!-- 配置后置通知 -->
<aop:after-returning method="afterReturningPrintLog" pointcut-ref="pt1"></aop:after-returning>
<!-- 配置异常通知 -->
<aop:after-throwing method="afterThrowingPrintLog" pointcut-ref="pt1"></aop:after-throwing>
<!-- 配置最终通知 -->
<aop:after method="afterPrintLog" pointcut-ref="pt1"></aop:after>
<!-- 配置切入点表达式 id属性用于指定表达式的唯一标识 expression用于指定表达式内容 -->
<!-- 此标签写在aop:aspect标签内部,只能当前切面使用,它还可以写在aop:aspect外面,所有切面可用 -->
<aop:pointcut id="pt1" expression="execution(* com.qublog.service.impl.*.*(..))"></aop:pointcut>
</aop:aspect>
</aop:config>
</beans>
或者
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:aop="http://www.springframework.org/schema/aop"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/aop
http://www.springframework.org/schema/aop/spring-aop.xsd">
<!-- 配置spring的ioc,把service对象配置进来 -->
<bean id="accountService" class="com.qublog.service.impl.AccountServiceImpl"></bean>
<!-- spring中基于xml的aop配置步骤 -->
<!-- 配置Logger类 -->
<bean id="logger" class="com.qublog.utils.Logger"></bean>
<!-- 配置aop -->
<aop:config>
<!-- 配置切入点表达式 id属性用于指定表达式的唯一标识 expression用于指定表达式内容 -->
<!-- 此标签写在aop:aspect标签内部,只能当前切面使用,它还可以写在aop:aspect外面,所有切面可用 -->
<aop:pointcut id="pt1" expression="execution(* com.qublog.service.impl.*.*(..))"></aop:pointcut>
<!-- 配置切面 -->
<aop:aspect id="logAdvice" ref="logger">
<!-- 配置前置通知 -->
<aop:before method="beforePrintLog" pointcut-ref="pt1"></aop:before>
<!-- 配置后置通知 -->
<aop:after-returning method="afterReturningPrintLog" pointcut-ref="pt1"></aop:after-returning>
<!-- 配置异常通知 -->
<aop:after-throwing method="afterThrowingPrintLog" pointcut-ref="pt1"></aop:after-throwing>
<!-- 配置最终通知 -->
<aop:after method="afterPrintLog" pointcut-ref="pt1"></aop:after>
</aop:aspect>
</aop:config>
</beans>