Spring代理模式总结

spring三种代理模式

1.静态代理

  • 目标类需要实现一个目标类接口
  • 需要自己写一个代理类用来融合目标类方法和切面类通知

2.JDK动态代理

  • 目标类需要实现一个目标类接口
  • 代理对象是目标接口的一个子类
  • 需要一个拦截器,实现InvocationHandler接口,重写invoke方法,融合目标类方法和切面类通知
  • 拦截器提供有参构造函数用来注入属性
  • 测试类将目标类,切面类都传入拦截器对象
  • 测试类中使用Proxy.newProxyInstance(loader, interfaces, h),JDK会自动生成一个代理类
  • 代理类调用目标方法会先走拦截器的invoke方法,invoke方法里面的method.invoke(target,args)才是真正调用目标方法

3.cglib包动态代理

  • 不需要目标类接口就可以产生代理对象
  • 代理对象是目标类的一个子类
  • 需要一个拦截器,实现MethodInterceptor接口,重写intercept方法,融合目标类方法和切面类通知
  • 拦截器提供有参构造函数用来注入属性
  • 拦截器,提供createProxy方法,里面是固定写法
  • 测试类调用拦截器的createProxy方法即可使用cglib包生成一个代理对象

spring框架实现动态代理

  • 目标类实现接口,则sping框架用JDK创建代理类
    getBean获得的是PersonDao类型
  • 目标类没有实现接口,则sping框架用Cglib包创建代理类
    getBean获得的是PersonDaoImpl类型

XML方式

  • 先将目标类和切面类加载到Spring作用域中
  • 使用aop配置将目标类和切面类柔和到一起
  • 并通过切入点表达式配置切面配置告诉切面类的通知融合到目标类的哪个目标方法中

注解方式

  • 目标类加载对象注解@Component(“personDao”)
  • 事务类加载对象注解@Component(“m”)
  • 事务类切面注解@Aspect
  • 事务类通知注解
    前置:@Before(“execution (* com.jp.aop.PersonDaoImpl.(…))")
    后置:@AfterReturning(value="execution (
    com.jp.aop.PersonDaoImpl.(…))",returning=“ret”)
    异常:@AfterThrowing(value="execution (
    com.jp.aop.PersonDaoImpl.(…))",throwing=“xx”)
    最终:@After("execution (
    com.jp.aop.PersonDaoImpl.(…))")
    环绕:@Around("execution (
    com.jp.aop.PersonDaoImpl.*(…))”)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值