spring中用joinpoint来访问目标方法的参数

本文深入讲解了面向切面编程(AOP)技术中的JointPoint方法,包括如何通过getArgs(), getTarget()和getSignature()访问目标方法参数及信息,并提供了具体的代码示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

概念:访问目标方法即用jointpoint(@around用poceedingjointpoint)1.获取他们的目标对象信息,如test.component@80387a这种,2.还有获取带参方法的参数,如[Ljava.lang.Object;@183cfe9(想当然我们也可以用对象的arrays.toString()方法将其还原) 3.另外还有获取被增强的方法相关信息 如String test.component.test1(String)这种

总结:访问目标方法参数,有三种方法(实际有四种,先说三种)

1.joinpoint.getargs():获取带参方法的参数

2.joinpoint.getTarget():.获取他们的目标对象信息

3..joinpoint.getSignature():(signature是信号,标识的意思):获取被增强的方法相关信息

看不懂,请看代码!

我以@afterreturning为例解说

我们先看3 Signature方法

@AfterReturning(value="execution(* test.*.*(..))",returning="name2")
    private void test1(JoinPoint jp ,String name2) {

                        System.out.println(jp.getSignature());

                        //其实getSignature()方法还有有用的方法,如:getDeclaringTypeName和getname();    前者是一个返回方法所在的包名和类名后者是返回方法名

                        System.out.println(jp.getSignature().getName());
                        System.out.println(jp.getSignature().getDeclaringTypeName());

}


组件类
@Component
public class component {
    
    public void test() {
        
    }
    public void test1(String name2) {
        
    }
}

Signature方法下的输出结果


你看,getSignature());是获取到这样的信息                修饰符   +    包名   +    组件名(类名)     +  方法的名字

         getSignature().getName());                               方法名

        getSignature().getDeclaringTypeName());      包名   +  组件名(类名)

我们再看1   getargs()

       System.out.println(jp.getArgs());
        System.out.println(Arrays.toString(jp.getArgs()));


结果输出



         jp.getArgs()                                 我们会得到一个  看不懂一组数组对象,但是我们知道这是一个对象,参数对象       
        Arrays.toString(jp.getArgs())     但是我们可以用Arrays类中数组转字符串方法:arrays.tostring(返回指定数组内容以字符串表示出来)  就可以得到具体数字了


3.getTarget()方法:该方法返回被织入增强处理的目标对象.(这个和getthis()方法很相似 但是的出来的值不相等)

System.out.println(jp.getTarget());

输出结果



是一个实实在在的对象,既不是参数也不是相关信息


总结:

以上就是访问目标方法的参数的所有方法(除了getthis()没有说其实也是返回一个对象生成的代理对象    得出的对象与gettarget()方法很相似几乎可以说是一模一样的,但是我用过.eqauls和==都不相等)这些方法,让我想起了 document(dom)编程的获取元素docuemnt.getelementbyid();  获取这些元素可以进行修改或者观察自己代码是否有异样.



<think>好的,用户让我把切入点改为com.sand.biz.domain.QtClockInRecord这个实体。我需要先理解这个问题的背景。 首先,用户可能是在开发一个Java应用,可能用到了Spring框架,特别是AOP(面向切面编程)。切入点(Pointcut)是AOP中用来定义在哪些连接点(比如方法执行)应用通知(Advice)的表达式。用户可能之前使用了其他实体类作为切入点,现在需要切换到QtClockInRecord。 接下来,我需要确认用户的具体需求。用户是否要监控该实体类的方法调用?或者是在该实体类的某些方法上应用事务管理、日志记录等?不同的场景会影响切入点的写法。 然后,考虑QtClockInRecord类的位置。包结构是com.sand.biz.domain,说明这是一个业务领域的实体类。通常实体类包含属性和getter/setter方法,可能还有一些业务逻辑方法。如果用户想切入这些方法,可能需要使用execution表达式。 假设用户需要监控所有public方法,切入点表达式可能是:execution(* com.sand.biz.domain.QtClockInRecord.*(..))。如果需要更细化,比如只切入特定方法,可能需要调整表达式。 另外,用户可能遇到之前的切入点不生效的问题,需要检查包名是否正确,是否被Spring管理,以及AOP配置是否正确。例如,确保类被Spring代理,且切入点表达式没有拼写错误。 可能用户在使用注解驱动或XML配置,需要确认配置方式。如果是注解,@Pointcut注解是否正确应用。还需要考虑Spring AOP的局限性,比如只能切入Spring管理的bean的方法。 最后,给出示例代码,说明如何定义切面和切入点,并提醒用户可能的注意事项,比如访问修饰符、返回类型方法参数等。确保用户能正确应用新的切入点。</think>关于将切入点调整为`com.sand.biz.domain.QtClockInRecord`实体的AOP配置,以下是技术实现建议: 1. **切入点表达式**(建议使用execution表达式): ```java @Pointcut("execution(* com.sand.biz.domain.QtClockInRecord.*(..))") public void qtClockInRecordOperation() {} ``` 2. **典型应用场景**: - 打卡记录创建/修改的审计日志 - 数据持久化前的参数校验 - 敏感字段的加解密处理 - 业务操作的事务管理 - 性能监控埋点 3. **增强建议组合**: ```java @Around("qtClockInRecordOperation()") public Object aroundAdvice(ProceedingJoinPoint pjp) throws Throwable { // 前置处理(如参数校验) Object result = pjp.proceed(); // 后置处理(如日志记录) return result; } ``` 4. **注意事项**: ✅ 确认实体类已被Spring管理(如使用@Entity注解) ✅ 需要排除Object类继承的方法(toString/hashCode等) ✅ 注意final方法无法被动态代理的问题 ✅ 推荐配合@annotation使用进行细粒度控制 5. **调试建议**: 可通过获取目标类信息验证切入点有效性: ```java @Before("qtClockInRecordOperation()") public void logMethod(JoinPoint joinPoint) { logger.info("Intercepted: " + joinPoint.getTarget().getClass().getName()); } ```
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值