spring的基于xml的AOP配置案例和切入点表达式的一些写法

时间:2023-03-09 09:44:18
spring的基于xml的AOP配置案例和切入点表达式的一些写法
<?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.com.service.impl.AccountServiceImpl"></bean> <!--
配置spring的基于xml的AOP
1.把通知bean交给spring来管理
2.使用aop:config标签表明开始AOP的配置
3.使用aop:aspect标签开始配置切面
属性:
id:给切面提供一个唯一标识
ref:指定通知类bean的id
4.在aop:aspect标签内部使用对应标签来配置通知的类型
现在是让printLog方法在切入点方法执行之前执行,所以是前置通知
aop:before:表示配置前置通知
属性:
method:用于指定Logger类中哪个方法是前置通知
pointcut:用于指定切入点表达式,该表达式的含义指的是对业务层中哪些方法进行增强
切入点表达式的写法:
关键字:execution(表达式)
表达式的写法:
访问修饰符 返回值 包名.包名.包名...类名.方法名(参数列表)
标准的表达式写法:
public void com.com.service.impl.AccountServiceImpl.saveAccount()
访问修饰符可以省略
void com.com.service.impl.AccountServiceImpl.saveAccount()
返回值可以使用通配符,表示任意返回值
* com.com.service.impl.AccountServiceImpl.saveAccount()
包名可以使用通配符,表示任意包,但是有几级包,就写几个*.
* *.*.*.*.AccountServiceImpl.saveAccount()
包名可以使用..表示当前包及其子包
* *..AccountServiceImpl.saveAccount()
类名和方法名都可以使用*来表示通配
* *..*.*()
参数列表:
可以直接写数据类型
基本数据类型直接写: int
* *..*.*(int)
引用数据类型写包名.类名: java.lang.String
* *..*.*(java.lang.String)
可以使用通配符,表示任意参数类型,但是必须有参数
* *..*.*(*)
可以使用..表示有无参数都可,且参数类型任意也就是全通配写法:
表达式的全通配写法:
* *..*.*(..)
实际开发中切入点方法的表达式通常的写法:
切到业务层实现类下的所有方法
* com.com.service.impl.*.*(..)
-->
<!--配置Logger类-->
<bean id="logger" class="com.com.utils.Logger"></bean>
<!--配置AOP-->
<aop:config>
<!--
配置切面表达式 id属性是设置表达式的唯一标识,exprission属性是写表达式的内容
此标签写在aop:aspect标签内部,那么只能是当前切面使用,
如果此标签卸载aop:aspect标签外部,则所有切面都可以使用,但是要注意顺序,只能在aop:aspect标签上面,不能在下面,
-->
<aop:pointcut id="pt1" expression="execution(* com.com.service.impl.*.*(..))"/>
<!--配置切面-->
<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>