spring-aop 余下部分 注解实现

由其另一种方式的衍生——.xml形式,自定义切入类,存在标签——自定义切入类(<aop:aspect ref=""> 涵盖代理类<aop:pointcut <aop:before/ <aop:after/)

把这种写法改为注解形式——

package testAOP;

import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.After;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Before;

@Aspect
public class annotationAop {
//注解实现 不具备expression= 前缀。
    @Before("execution(* demoAop.UserserviceImpl.*(..))")
    public void before()
    {
 System.out.println("方法执行之前:");
    }

    @After("execution(* demoAop.UserserviceImpl.*(..))")
    public void after()
    {
System.out.println("方法执行之后:");
    }
    @Around("execution(* testAOP.ServiceImpl.*(..))")//环绕通知 方法前后 安全
    public void around(ProceedingJoinPoint jp) throws Throwable{
        System.out.println("环绕前:");
        System.out.println("签名"+jp.getSignature());
        // 执行目标方法proceed
        Object proceed=jp.proceed();//joinpoint 是连接点 为该代理类执行方法本身 含有拦截器。进行代理的时候,调用拦截器MethodInterceptor的加强方法,执行代理方法。
        System.out.println("环绕后");
        System.out.println(proceed);
    }
}

在Spring配置文件中,注册bean,并增加支持注解的配置

<bean id="annotationAop" class="testAOP.annotationAop"/>
    <aop:aspectj-autoproxy/>
    <!--<aop:aspectj-autoproxy />有一个proxy-target-class属性,默认为false,表示使用jdk动态代理织入增强,当配为<aop:aspectj-autoproxy  poxy-target-class="true"/>时,表示使用CGLib动态代理技术织入增强。不过即使proxy-target-class设置为false,如果目标类没有声明接口,则spring将自动使用CGLib动态代理。-->

笔记部分在代码注释中。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值