重庆分公司,新征程启航

为企业提供网站建设、域名注册、服务器等服务

SpringAOP中怎么访问目标方法的参数-创新互联

这篇文章给大家介绍SpringAOP中怎么访问目标方法的参数,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。

为淮上等地区用户提供了全套网页设计制作服务,及淮上网站建设行业解决方案。主营业务为成都做网站、网站设计、外贸营销网站建设、淮上网站设计,以传统方式定制建设网站,并提供域名空间备案等一条龙服务,秉承以专业、用心的态度为用户提供真诚的服务。我们深信只要达到每一位用户的要求,就会得到认可,从而选择与我们长期合作。这样,我们也可以走得更远!

一 配置


               

二 切面类

package org.crazyit.app.aspect;import org.aspectj.lang.annotation.*;import org.aspectj.lang.*;import java.util.Arrays;// 定义一个切面@Aspectpublic class FourAdviceTest{  // 定义Around增强处理  @Around("execution(* org.crazyit.app.service.impl.*.*(..))")  public Object processTx(ProceedingJoinPoint jp)    throws java.lang.Throwable  {    System.out.println("Around增强:执行目标方法之前,模拟开始事务...");    // 访问执行目标方法的参数    Object[] args = jp.getArgs();    // 当执行目标方法的参数存在,    // 且第一个参数是字符串参数    if (args != null && args.length > 0      && args[0].getClass() == String.class)    {      // 修改目标方法调用参数的第一个参数      args[0] = "【增加的前缀】" + args[0];    }    //执行目标方法,并保存目标方法执行后的返回值    Object rvt = jp.proceed(args);    System.out.println("Around增强:执行目标方法之后,模拟结束事务...");    // 如果rvt的类型是Integer,将rvt改为它的平方    if(rvt != null && rvt instanceof Integer)      rvt = (Integer)rvt * (Integer)rvt;    return rvt;  }  // 定义Before增强处理  @Before("execution(* org.crazyit.app.service.impl.*.*(..))")  public void authority(JoinPoint jp)  {    System.out.println("Before增强:模拟执行权限检查");    // 返回被织入增强处理的目标方法    System.out.println("Before增强:被织入增强处理的目标方法为:"      + jp.getSignature().getName());    // 访问执行目标方法的参数    System.out.println("Before增强:目标方法的参数为:"      + Arrays.toString(jp.getArgs()));    // 访问被增强处理的目标对象    System.out.println("Before增强:被织入增强处理的目标对象为:"      + jp.getTarget());  }  //定义AfterReturning增强处理  @AfterReturning(pointcut="execution(* org.crazyit.app.service.impl.*.*(..))"    , returning="rvt")  public void log(JoinPoint jp , Object rvt)  {    System.out.println("AfterReturning增强:获取目标方法返回值:"      + rvt);    System.out.println("AfterReturning增强:模拟记录日志功能...");    // 返回被织入增强处理的目标方法    System.out.println("AfterReturning增强:被织入增强处理的目标方法为:"      + jp.getSignature().getName());    // 访问执行目标方法的参数    System.out.println("AfterReturning增强:目标方法的参数为:"      + Arrays.toString(jp.getArgs()));    // 访问被增强处理的目标对象    System.out.println("AfterReturning增强:被织入增强处理的目标对象为:"      + jp.getTarget());  }  // 定义After增强处理  @After("execution(* org.crazyit.app.service.impl.*.*(..))")  public void release(JoinPoint jp)  {    System.out.println("After增强:模拟方法结束后的释放资源...");    // 返回被织入增强处理的目标方法    System.out.println("After增强:被织入增强处理的目标方法为:"      + jp.getSignature().getName());    // 访问执行目标方法的参数    System.out.println("After增强:目标方法的参数为:"      + Arrays.toString(jp.getArgs()));    // 访问被增强处理的目标对象    System.out.println("After增强:被织入增强处理的目标对象为:"      + jp.getTarget());  }}

三 接口

Hello

package org.crazyit.app.service;public interface Hello {   // 定义一个简单方法,模拟应用中的业务逻辑方法   void foo();   // 定义一个addUser()方法,模拟应用中的添加用户的方法   int addUser(String name, String pass);}

World

package org.crazyit.app.service;public interface World {   // 定义一个简单方法,模拟应用中的业务逻辑方法   public void bar();}

四 实现类

HelloImpl

package org.crazyit.app.service.impl;import org.springframework.stereotype.Component;import org.crazyit.app.service.*;@Component("hello")public class HelloImpl implements Hello {  // 定义一个简单方法,模拟应用中的业务逻辑方法  public void foo() {    System.out.println("执行Hello组件的foo()方法");  }  // 定义一个addUser()方法,模拟应用中的添加用户的方法  public int addUser(String name, String pass) {    System.out.println("执行Hello组件的addUser添加用户:" + name);    return 20;  }}

WorldImpl

package org.crazyit.app.service.impl;import org.springframework.stereotype.Component;import org.crazyit.app.service.*;@Component("world")public class WorldImpl implements World {  // 定义一个简单方法,模拟应用中的业务逻辑方法  public void bar() {    System.out.println("执行World组件的bar()方法");  }}

五 测试类

package lee;import org.springframework.context.*;import org.springframework.context.support.*;import org.crazyit.app.service.*;public class BeanTest {  public static void main(String[] args) {    // 创建Spring容器    ApplicationContext ctx = new ClassPathXmlApplicationContext("beans.xml");    Hello hello = ctx.getBean("hello", Hello.class);    hello.foo();    hello.addUser("孙悟空", "7788");    World world = ctx.getBean("world", World.class);    world.bar();  }}

六 测试结果

Around增强:执行目标方法之前,模拟开始事务...Before增强:模拟执行权限检查Before增强:被织入增强处理的目标方法为:fooBefore增强:目标方法的参数为:[]Before增强:被织入增强处理的目标对象为:org.crazyit.app.service.impl.HelloImpl@694abbdc执行Hello组件的foo()方法Around增强:执行目标方法之后,模拟结束事务...After增强:模拟方法结束后的释放资源...After增强:被织入增强处理的目标方法为:fooAfter增强:目标方法的参数为:[]After增强:被织入增强处理的目标对象为:org.crazyit.app.service.impl.HelloImpl@694abbdcAfterReturning增强:获取目标方法返回值:nullAfterReturning增强:模拟记录日志功能...AfterReturning增强:被织入增强处理的目标方法为:fooAfterReturning增强:目标方法的参数为:[]AfterReturning增强:被织入增强处理的目标对象为:org.crazyit.app.service.impl.HelloImpl@694abbdcAround增强:执行目标方法之前,模拟开始事务...Before增强:模拟执行权限检查Before增强:被织入增强处理的目标方法为:addUserBefore增强:目标方法的参数为:[【增加的前缀】孙悟空, 7788]Before增强:被织入增强处理的目标对象为:org.crazyit.app.service.impl.HelloImpl@694abbdc执行Hello组件的addUser添加用户:【增加的前缀】孙悟空Around增强:执行目标方法之后,模拟结束事务...After增强:模拟方法结束后的释放资源...After增强:被织入增强处理的目标方法为:addUserAfter增强:目标方法的参数为:[【增加的前缀】孙悟空, 7788]After增强:被织入增强处理的目标对象为:org.crazyit.app.service.impl.HelloImpl@694abbdcAfterReturning增强:获取目标方法返回值:400AfterReturning增强:模拟记录日志功能...AfterReturning增强:被织入增强处理的目标方法为:addUserAfterReturning增强:目标方法的参数为:[【增加的前缀】孙悟空, 7788]AfterReturning增强:被织入增强处理的目标对象为:org.crazyit.app.service.impl.HelloImpl@694abbdcAround增强:执行目标方法之前,模拟开始事务...Before增强:模拟执行权限检查Before增强:被织入增强处理的目标方法为:barBefore增强:目标方法的参数为:[]Before增强:被织入增强处理的目标对象为:org.crazyit.app.service.impl.WorldImpl@2e005c4b执行World组件的bar()方法Around增强:执行目标方法之后,模拟结束事务...After增强:模拟方法结束后的释放资源...After增强:被织入增强处理的目标方法为:barAfter增强:目标方法的参数为:[]After增强:被织入增强处理的目标对象为:org.crazyit.app.service.impl.WorldImpl@2e005c4bAfterReturning增强:获取目标方法返回值:nullAfterReturning增强:模拟记录日志功能...AfterReturning增强:被织入增强处理的目标方法为:barAfterReturning增强:目标方法的参数为:[]AfterReturning增强:被织入增强处理的目标对象为:org.crazyit.app.service.impl.WorldImpl@2e005c4b

关于SpringAOP中怎么访问目标方法的参数就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。


本文名称:SpringAOP中怎么访问目标方法的参数-创新互联
网页网址:http://cqcxhl.com/article/cojdio.html

其他资讯

在线咨询
服务热线
服务热线:028-86922220
TOP