1、创建目标类
/**
* @author 作者 Your-Name:
* @version 创建时间:2019年5月31日 上午10:35:08
* 类说明
*/
package com.sumeng.aop;
/**
* @author Administrator
*
*/
public class UserInfo {
public void add(){
System.out.println("添加数据中!!!!");
}
public String delete(){
System.out.println("删除数据中!!!!");
return "麒麟";
}
public void update(){
System.out.println("修改数据中!!!!");
}
public void check(){
System.out.println("查找数据中!!!!");
//int i = 5/0;
}
}
2、创建切面类
/**
* @author 作者 Your-Name:
* @version 创建时间:2019年5月31日 上午10:37:25
* 类说明
*/
package com.sumeng.aop;
import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.After;
import org.aspectj.lang.annotation.AfterReturning;
import org.aspectj.lang.annotation.AfterThrowing;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Before;
import org.aspectj.lang.annotation.Pointcut;
/**
* @author Administrator
*
*/
//将切面类交给Spring管理
@Aspect
public class UserInfoAop {
//前置通知
@Before(value="execution (* com.sumeng.aop.UserInfo.add(..))")
public void check(JoinPoint point){
System.out.println("添加数据之前执行的方法!!!!"+point);
}
//后置通知
@AfterReturning(value="execution (* com.sumeng.aop.UserInfo.de*(..))",returning="log")
public void checkDelect(Object log){
System.out.println("保存日志信息之后执行!!!"+log);
}
//环绕通知
@Around(value="execution (* com.sumeng.aop.UserInfo.up*(..))")
public Object around(ProceedingJoinPoint joinPoint) throws Throwable{
System.out.println("环绕通知之前执行的方法!!!!");
Object obj = joinPoint.proceed();
System.out.println("环绕通知之后执行的方法!!!!");
return obj;
}
//异常通知
@AfterThrowing(value="execution (* com.sumeng.aop.UserInfo.che*(..))",throwing="ex")
public void checkQuery(JoinPoint ex){
System.out.println("异常错误"+ ex);
}
//始终通知
@After(value="UserInfoAop.pointcut()")
public void after(){
System.out.println("始终通知!!!!");
}
//切入点 简化注入 相当于给@给了个 id
@Pointcut(value="execution (* com.sumeng.aop.UserInfo.c*(..))")
public void pointcut(){}
}
有@的就是注解配置 去掉@就是xml配置
3、注解测试
/**
* @author 作者 Your-Name:
* @version 创建时间:2019年6月20日 下午3:10:21
* 类说明
*/
package com.sumeng.action;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
import com.sumeng.aop.UserInfo;
/**
* @author Administrator
*
*/
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration("classpath:config/applicationContext.xml")
public class Demo {
@Autowired
private UserInfo user;
@org.junit.Test
public void demoOne(){
user.add();
}
}
4、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:context="http://www.springframework.org/schema/context"
xmlns:aop="http://www.springframework.org/schema/aop"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-4.0.xsd
http://www.springframework.org/schema/aop
http://www.springframework.org/schema/aop/spring-aop-4.0.xsd">
<!--
init-method="getstart" 该类初始化执行的方法
destroy-method="getdestroy" 该类被销毁时执行的方法
scope="singleton" 默认为单列模式 可以 不写
scope="prototype" 多列模式
<property name="该类的属性名" value="给该类属性名注入的值"></property>
<import resource="user.xml"/> 若有多个配置文件可以用 inport
-->
<!-- <bean id="car" class="com.sumeng.web.Car" init-method="getstart" destroy-method="getdestroy" scope="">
<property name="carName" value="奥迪"></property>
</bean>
<import resource="user.xml"/>-->
<!-- 通过 注解 注入 类扫描器 -->
<!-- <context:component-scan base-package="com.sumeng.web"></context:component-scan>-->
<bean id="userInfo" class="com.sumeng.aop.UserInfo" ></bean>
<bean id="userInfoAop" class="com.sumeng.aop.UserInfoAop" ></bean>
<!-- 开启注解 -->
<context:annotation-config />
<!-- Aop配置 -->
<aop:config>
<!-- 配置切入点pointcut -->
<aop:pointcut expression="execution(* com.sumeng.aop.UserInfo.add(..))" id="userInfoPointcut"/>
<aop:pointcut expression="execution(* com.sumeng.aop.UserInfo.delete(..))" id="deletePointcut"/>
<aop:pointcut expression="execution(* com.sumeng.aop.UserInfo.update(..))" id="updatePointcut"/>
<aop:pointcut expression="execution(* com.sumeng.aop.UserInfo.check(..))" id="checkPointcut"/>
<!-- 配置切面 -->
<aop:aspect ref="userInfoAop">
<!-- 前置通知 -->
<aop:before method="check" pointcut-ref="userInfoPointcut"/>
<!-- 后置通知 -->
<aop:after-returning method="checkDelect" pointcut-ref="deletePointcut" returning="log"/>
<!-- 环绕通知 -->
<aop:around method="around" pointcut-ref="updatePointcut"/>
<!-- 异常通知 -->
<aop:after-throwing method="checkQuery" pointcut-ref="checkPointcut" throwing="ex"/>
<!-- 始终通知 -->
<aop:after method="checkQuery" pointcut-ref="checkPointcut"/>
</aop:aspect>
</aop:config>
</beans>