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">
<!--配置springioc,把service对象配置进来-->
<bean id="accountService" class="com.com.service.impl.AccountServiceImpl"></bean>

<!--
配置spring的基于xmlAOP
1.把通知bean交给spring来管理
2.使用aop:config标签表明开始AOP的配置
3.使用aop:aspect标签开始配置切面
属性:
id:给切面提供一个唯一标识
ref:指定通知类beanid
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>
<!--配置切面-->
<aop:aspect id="logAdvice" ref="logger">
<!--配置通知的类型,并且建立通知方法和切入点方法的关联-->
<aop:before method="printLog" pointcut="execution(* com.com.service.impl.*.*(..))"></aop:before>
</aop:aspect>
</aop:config>
</beans>

猜你喜欢

转载自www.cnblogs.com/wqy0314/p/11877290.html
今日推荐