Spring AOP访问目标方法的参数操作示例

网友投稿 253 2023-05-20

Spring AOP访问目标方法的参数操作示例

本文实例讲述了Spring AOP访问目标方法的参数操作。分享给大家供大家参考,具体如下:

一 配置

xmlns:xsi="http://w3.org/2001/XMLSchema-instance"

xmlns:context="http://springframework.org/schema/context"

xmlns:aop="http://springframework.org/schema/aop"

xsi:schemaLocation="http://springframework.org/schema/beans

http://springframework.org/schema/beans/spring-beans-4.0.xsd

http://springframework.org/schema/context

http://springframework.org/schema/context/spring-context-4.0.xsd

http://springframework.org/schema/aop

http://springframework.org/schema/aop/spring-aop-4.0.xsd">

base-package="org.crazyit.app.service

,org.crazyit.app.aspect">

expression="org.aspectj.lang.annotation.Aspect" />

xmlns:xsi="http://w3.org/2001/XMLSchema-instance"

xmlns:context="http://springframework.org/schema/context"

xmlns:aop="http://springframework.org/schema/aop"

xsi:schemaLocation="http://springframework.org/schema/beans

http://springframework.org/schema/beans/spring-beans-4.0.xsd

http://springframework.org/schema/context

http://springframework.org/schema/context/spring-context-4.0.xsd

http://springframework.org/schema/aop

http://springframework.org/schema/aop/spring-aop-4.0.xsd">

base-package="org.crazyit.app.service

,org.crazyit.app.aspect">

expression="org.aspectj.lang.annotation.Aspect" />

base-package="org.crazyit.app.service

,org.crazyit.app.aspect">

expression="org.aspectj.lang.annotation.Aspect" />

expression="org.aspectj.lang.annotation.Aspect" />

二 切面类

package org.crazyit.app.aspect;

import org.aspectj.lang.annotation.*;

import org.aspectj.lang.*;

import java.util.Arrays;

// 定义一个切面

@Aspect

public 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(UOnGhGOOR);

hello.addUser("孙悟空", "7788");

World world = ctx.getBean("world", World.class);

world.bar();

}

}

六 测试结果

Around增强:执行目标方法之前,模拟开始事务...

Before增强:模拟执行权限检查

Before增强:被织入增强处理的目标方法为:foo

Before增强:目标方法的参数为:[]

Before增强:被织入增强处理的目标对象为:org.crazyit.app.service.impl.HelloImpl@694abbdc

执行Hello组件的foo()方法

Around增强:执行目标方法之后,模拟结束事务...

After增强:模拟方法结束后的释放资源...

After增强:被织入增强处理的目标方法为:foo

After增强:目标方法的参数为:[]

After增强:被织入增强处理的目标对象为:org.crazyit.app.service.impl.HelloImpl@694abbdc

AfterReturning增强:获取目标方法返回值:null

AfterReturning增强:模拟记录日志功能...

AfterReturning增强:被织入增强处理的目标方法为:foo

AfterReturning增强:目标方法的参数为:[]

AfterReturning增强:被织入增强处理的目标对象为:org.crazyit.app.service.impl.HelloImpl@694abbdc

Around增强:执行目标方法之前,模拟开始事务...

Before增强:模拟执行权限检查

Before增强:被织入增强处理的目标方法为:addUser

Before增强:目标方法的参数为:[【增加的前缀】孙悟空, 7788]

Before增强:被织入增强处理的目标对象为:org.crazyit.app.service.impl.HelloImpl@694abbdc

执行Hello组件的addUser添加用户:【增加的前缀】孙悟空

Around增强:执行目标方法之后,模拟结束事务...

After增强:模拟方法结束后的释放资源...

After增强:被织入增强处理的目标方法为:addUser

After增强:目标方法的参数为:[【增加的前缀】孙悟空, 7788]

After增强:被织入增强处理的目标对象为:org.crazyit.app.service.impl.HelloImpl@694abbdc

AfterReturning增强:获取目标方法返回值:400

AfterReturning增强:模拟记录日志功能...

AfterReturning增强:被织入增强处理的目标方法为:addUser

AfterReturning增强:目标方法的参数为:[【增加的前缀】孙悟空, 7788]

AfterReturning增强:被织入增强处理的目标对象为:org.crazyit.app.service.impl.HelloImpl@694abbdc

Around增强:执行目标方法之前,模拟开始事务...

Before增强:模拟执行权限检查

Before增强:被织入增强处理的目标方法为:bar

Before增强:目标方法的参数为:[]

Before增强:被织入增强处理的目标对象为:org.crazyit.app.service.impl.WorldImpl@2e005c4b

执行World组件的bar()方法

Around增强:执行目标方法之后,模拟结束事务...

After增强:模拟方法结束后的释放资源...

After增强:被织入增强处理的目标方法为:bar

After增强:目标方法的参数为:[]

After增强:被织入增强处理的目标对象为:org.crazyit.app.service.impl.WorldImpl@2e005c4b

AfterReturning增强:获取目标方法返回值:null

AfterReturning增强:模拟记录日志功能...

AfterReturning增强:被织入增强处理的目标方法为:bar

AfterReturning增强:目标方法的参数为:[]

AfterReturning增强:被织入增强处理的目标对象为:org.crazyit.app.service.impl.WorldImpl@2e005c4b

更多关于java相关内容感兴趣的读者可查看本站专题:《Spring框架入门与进阶教程》、《Java数据结构与算法教程》、《Java操作DOM节点技巧总结》、《Java文件与目录操作技巧汇总》和《Java缓存操作技巧汇总》

希望本文所述对大家java程序设计有所帮助。

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Java并发 CompletableFuture异步编程的实现
下一篇:spring AOP的Around增强实现方法分析
相关文章

 发表评论

暂时没有评论,来抢沙发吧~