springboot---AOP

https://blog.csdn.net/JAVA_MHH/article/details/121318263
在这里插入图片描述
@within和@target针对类的注解,@annotation是针对方法的注解

@Pointcut("execution(* com.sxf.oms.web.feign.*.*(..))")

切入点表达式:

整个表达式可以分为五个部分:
1execution(): 表达式主体。
2、第一个*号:方法返回类型, *号表示所有的类型。
3、包名:表示需要拦截的包名。
4、第二个*号:表示类名,*号表示所有的类。
5*(..):最后这个星号表示方法名,*号表示所有的方法,后面( )里面表示方法的参数,两个句点表示任何参数
  execution(* 包名.*.*(..))

规范写法:execution(* com.baizhi.service.UserServiceImpl.*(..))重点    最通用的        //执行接口下的所有接口方法
===========================================================================================

    书写接口实现方法:UserServiceImpl     

    方法类型:add();   query();    add(String name);   add(User user);  add(String name,Integer age);
    execution(* service.UserServiceImpl.add(..))        //执行add()方法
    execution(* service.UserServiceImpl.add(String))    //执行add(String name)方法
    execution(* service.UserServiceImpl.add(com.baizhi.entity.User))    //执行add(User user)方法
    execution(* service.UserServiceImpl.add(String , Integer))    //执行add(String name,Interger age)方法



@Pointcut("@within(org.springframework.cloud.openfeign.FeignClient)")  //@within和@target针对类的注解
定义
格式:@ 注解(value=“表达标签 ( 表达式格式))
如:@Pointcut (value=execution(* com.cn.spring.aspectj.NotVeryUsefulAspectService.*()))
表达式标签
execution():用于匹配方法执行的连接点
args(): 用于匹配当前执行的方法传入的参数为指定类型的执行方法
this(): 用于匹配当前AOP代理对象类型的执行方法;注意是AOP代理对象的类型匹配,这样就可能包括引入接口也类型匹配;
target(): 用于匹配当前目标对象类型的执行方法;注意是目标对象的类型匹配,这样就不包括引入接口也类型匹配;
within(): 用于匹配指定类型内的方法执行;
@args():于匹配当前执行的方法传入的参数持有指定注解的执行;
@target():用于匹配当前目标对象类型的执行方法,其中目标对象持有指定的注解;
@within():用于匹配所以持有指定注解类型内的方法;
@annotation:用于匹配当前执行方法持有指定注解的方法;
其中execution 是用的最多的,
execution
execution格式:
execution(
modifier-pattern?ret-type-patterndeclaring-type-pattern?name-pattern(param-pattern)throws-pattern?
)
execution(modifiers-pattern? ret-type-pattern declaring-type-pattern? name-pattern(param-pattern)throws-pattern?)
其中带 ?号的 modifiers-pattern?,declaring-type-pattern?,hrows-pattern?是可选项
ret-type-pattern,name-pattern, parameters-pattern是必选项;
modifier-pattern? 修饰符匹配,如public 表示匹配公有方法
ret-type-pattern 返回值匹配,* 表示任何返回值,全路径的类名等
declaring-type-pattern? 类路径匹配
name-pattern 方法名匹配,* 代表所有,set*,代表以set开头的所有方法
(param-pattern) 参数匹配,指定方法参数(声明的类型),
         (..)代表所有参数,
         ()代表一个参数,
         (,String)代表第一个参数为任何值,第二个为String类型.
throws-pattern? 异常类型匹配
例子:
execution(public * *(..)) 定义任意公共方法的执行
execution(* set*(..)) 定义任何一个以"set"开始的方法的执行
execution(* com.xyz.service.AccountService.*(..)) 定义AccountService 接口的任意方法的执行
execution(* com.xyz.service.*.*(..)) 定义在service包里的任意方法的执行
execution(* com.xyz.service ..*.*(..)) 定义在service包和所有子包里的任意类的任意方法的执行
execution(* com.test.spring.aop.pointcutexp…JoinPointObjP2.*()) 定义在pointcutexp包和所有子包里的JoinPointObjP2类的任意方法的执行:
说明:最靠近(..)的为方法名,靠近.(..))的为类名或者接口名,如上例的JoinPointObjP2.(..))


visitTime = new Date();//当前时间就是开始访问的时间
clazz = jp.getTarget().getClass(); //具体要访问的类
String methodName = jp.getSignature().getName(); //获取访问的方法的名称
Object[] args = jp.getArgs();//获取访问的方法的参数

例子

@Aspect
@Slf4j
@Component
public class WebLogAspect {

    @Pointcut("execution( * com.example.oms.controller..*.*(..))")
    public void logPointCut() {
    }


//    @Around("logPointCut()")
    public void doBefore(JoinPoint joinPoint) {
        // 接收到请求,记录请求内容
        ServletRequestAttributes attributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();
        assert attributes != null;
        HttpServletRequest request = attributes.getRequest();
        // 记录下请求内容
        log.info("请求地址 : {} , METHOD : {} , 请求参数 : {}", request.getRequestURL().toString(), request.getMethod(),
                JSONUtil.toJsonStr(joinPoint.getArgs()));

    }

    @Around("logPointCut()")
    public Object doBefore(ProceedingJoinPoint joinPoint) throws Throwable {
        // 接收到请求,记录请求内容
        ServletRequestAttributes attributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();
        assert attributes != null;
        HttpServletRequest request = attributes.getRequest();
        // 记录下请求内容
        log.info("请求地址 : {} , METHOD : {} , 请求参数 : {}", request.getRequestURL().toString(), request.getMethod(),
                JSONUtil.toJsonStr(joinPoint.getArgs()));
        Signature signature = joinPoint.getSignature();
        Object ret = joinPoint.proceed(joinPoint.getArgs());
        String targetClass = signature.getDeclaringTypeName();
        log.info("结果:{}",ret);
        return ret;
    }
}

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

zcy_code

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值