时间:2021-05-19
本文实例讲述了Spring AOP访问目标方法的参数操作。分享给大家供大家参考,具体如下:
一 配置
<?xml version="1.0" encoding="GBK"?><beans xmlns="http://ponent("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增强:被织入增强处理的目标方法为: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程序设计有所帮助。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
@Transactional内部调用例子🌰在Spring的AOP代理下,只有目标方法由外部调用,目标方法才由Spring生成的代理对象来管理,这
在阅读本文之前,大家可先参阅《简单理解Spring之IOC和AOP及代码示例》一文,了解下Spring中IOC和AOP的相关内容。下面进入正题。本篇文章介绍在S
spring对AOP的实现提供了很好的支持。下面我们就使用Spring的注解来完成AOP做一个例子。首先,为了使用Spring的AOP注解功能,必须导入如下几个
在阅读本文之前,大家可先行参阅《简单理解Spring之IOC和AOP及代码示例》一文,简单了解下ioc和aop的相关内容。下面进入正题。本文将会一步一步创建一个
Java反射机制与动态代理,使得Java更加强大,Spring核心概念IoC、AOP就是通过反射机制与动态代理实现的。1Java反射示例:Useruser=ne