使用Spring的API接口实现AOP
首先在pom.xml中导入AOP织入的依赖包
<dependency>
<groupId>aspectj</groupId>
<artifactId>aspectjweaver</artifactId>
<version>1.5.3</version>
</dependency>
编写Service层
Service接口
public interface UserService {
public void add();
public void delete();
public void update();
public void query();
}
ServiceImpl层
public class UserServiceImpl implements UserService {
@Override
public void add() {
System.out.println("增加了一个用户");
}
@Override
public void delete() {
System.out.println("删除了一个用户");
}
@Override
public void update() {
System.out.println("修改了一个用户");
}
@Override
public void query() {
System.out.println("查询了一个用户");
}
}
编写log通知
前置通知
import java.lang.reflect.Method;
/**
* @author Mi
* @version 1.0
* @description: TODO
* @date 2021/12/15 21:39
*/
public class log implements org.springframework.aop.MethodBeforeAdvice {
///method :要执行的目标对象的方法
// args:参数
//target:目标对象
@Override
public void before(Method method, Object[] args, Object target) throws Throwable {
System.out.println(target.getClass().getName()+"的"+ method.getName()+"被执行了");
}
}
后置通知
import org.springframework.aop.AfterReturningAdvice;
import java.lang.reflect.Method;
/**
* @author Mi
* @version 1.0
* @description: TODO
* @date 2021/12/15 21:46
*/
public class Afterlog implements AfterReturningAdvice {
@Override
public void afterReturning(Object returnValue, Method method, Object[] args, Object target) throws Throwable {
System.out.println("执行力" +method.getName()+"的方法,返回结果为"+returnValue);
}
}
编写applicationContext.xml文件
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns="http://www.springframework.org/schema/beans"
xmlns:aop="http://www.springframework.org/schema/aop"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-4.2.xsd
http://www.springframework.org/schema/aop
http://www.springframework.org/schema/aop/spring-aop.xsd
">
<!--注册bean-->
<bean id="userService" class="com.example.springaopdemo.Service.UserServiceImpl"/>
<bean id="log" class="com.example.springaopdemo.log.log"/>
<bean id="Afterlog" class="com.example.springaopdemo.log.Afterlog"/>
<!--配置aop,需要导入Aop的约束-->
<aop:config>
<!--切入点:experssion:表达式,execution(要执行的位置!)-->
<aop:pointcut id="pointcut" expression="execution(* com.example.springaopdemo.Service.UserServiceImpl.*(..))"/>
<!--执行环绕增加!-->
<aop:advisor advice-ref="log" pointcut-ref="pointcut"/>
<aop:advisor advice-ref="Afterlog" pointcut-ref="pointcut"/>
</aop:config>
</beans>
编写applicationContext.xml文件
import com.example.springaopdemo.Service.UserService;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
/**
* @author Mi
* @version 1.0
* @description: TODO
* @date 2021/12/15 22:57
*/
public class MyTest {
public static void main(String[] args) {
ApplicationContext context = new ClassPathXmlApplicationContext("applicationContext.xml");
//动态代理代理的是接口
UserService userService = (UserService) context.getBean("userService");
userService.add();
}
}
项目截图
运行结果