一、AOP概念
概念:面向切面编程(方面)利用AOP可以对业务逻辑的各个部分进行隔离,从而使得业务逻辑各部分之间的耦合度降低,提高程序的可重用性,同时提高了开发的效率。
通俗的说就是:不通过修改源代码方式,在主干功能里面添加新功能
AOP时ioc的一个新增的功能,是对Bean进行操作
另外补充两个概念:
OOP 面向对象编程
以对象为基本单位完成程序开发,通过对象间的相互协同,完成程序构建
POP 面向过程编程
以函数为基本单位完成程序开发,通过函数间的相互调用,完成程序构建
aop是ioc的一个扩展功能,先有的ioc,再有的aop,
只是在ioc的整个流程中新增的一个扩展点而已:BeanPostProcessor
总:
aop概念, 应用场景【记录日志,权限控制,缓存优化,监控方法运行时间】,动态代理
分
bean的创建过程中有一个步骤可以对bean进行扩展实现,aop本 身就是一个扩展功能,所以在BeanPostProcessor的后置处理方法中来进行实现1. 代理对象的创建过程(advice,切面, 切点)
2、通过jdk或者cglib的方式来生成代理对象
3在执行方法调用的时候,会调用到生成的字节码文件中,直接# 时找到DynamicAdvisoredinterceptor类中的intercep方法,从此
方法开始执行4根据之前定义好的通知来生成拦截器链
5.从拦截器链中依次获取每一个通知开始进行执行, 在执行过程中, 为了方便找到下一个通知是哪个,会有一个CglibMethodinvocation的对象, 找的时候是从-1的位置一次开始查找并且执行的。
二、AOP底层原理
1、使用JDK动态代理(基于接口的)
接口:
public interface StudentDao{
public int add(int a,int b);
public String update(String id);
}
实现类:
public class StudentDaoImpl implements StudentDao{
@Override
public int add(int a, int b) {
return a+b;
}
@Override
public String update(String id) {
return id;
}
}
代理类:
import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;
import java.util.Arrays;
public class JDKProxy {
public static void main(String[] args) {
//创建接口实现类代理方法
Class[] interfaces={StudentDao.class};
StudentDaoImpl userDao=new StudentDaoImpl();
StudentDao dao = (StudentDao) Proxy.newProxyInstance(JDKProxy.class.getClassLoader(), interfaces, new StudentDaoProxy(userDao));
int result= dao.add(1,2);
System.out.println(result);
}
}
//创建代理对象代码
class StudentDaoProxy implements InvocationHandler{
//1 把创建的是谁的代理对象,把谁传递进来
//有参构造传递
private Object obj;
public StudentDaoProxy(Object obj){
this.obj=obj;
}
//增强的逻辑
@Override
public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
//方法之前
System.out.println("方法之前执行..."+method.getName()+":传递的参数..."+ Arrays.toString(args));
//被增强的方法执行
Object res = method.invoke(obj, args);
//方法之后
System.out.println("方法之后执行.."+obj);
return res;
}
}
2、使用cglib动态代理
public class TestCjLib {
public static void main(String[] args) {
// 创建原始对象
UserService userService = new UserService();
// cglib创建代理对象
Enhancer enhancer = new Enhancer();
enhancer.setClassLoader(TestCjLib.class.getClassLoader());
enhancer.setSuperclass(UserService.class);
enhancer.setCallback(new MethodInterceptor() {
@Override
public Object intercept(Object o, Method method, Object[] objects, MethodProxy methodProxy) throws Throwable {
System.out.println("cglib--before");
Object ret = method.invoke(userService, "夏冬","123456");
System.out.println("cglib--after");
return ret;
}
});
UserService userServiceProxy = (UserService)enhancer.create();
userServiceProxy.login("xiadong","123456");
}
}
三、AOP相关术语
1.连接点
类里面哪些方法可以被增强,这些方法称为连接点
2.切入点
实际被真正增强的方法,称为切入点
3.通知(增强)
(1)实际增强的逻辑部分称为通知(增强)
(2)通知有多种类型
*前置通知
*后置通知
*环绕通知
*异常通知
*最终通知
4.切面
是动作
(1)把通知应用到切入点的过程