[code]
aop:
1: 编程式:
其中,必须先自己从spring中已有的adivce或pointcut advistor中继承或实现一个类,然后再通过代理(ProxyFactoryBean)中配置业务对象的接口(proxyInterfaces),业务对象的实现(target),及要向业务对象中织入(weave)的拦截器(interceptorNames),从而完成对一个业务对象的方法的拦截。
在使用时,从(applicationContext)中查找相应的代理对象,从而实现其拦截的目的。
2: 基于XML schema:
可以定义一个拦截对象,无需继承或实现任何接口,在applicationContext.xml中配置相应的内容(aop:config)即可
<aop:config>
<aop:pointcut id="point别名" expression="execution(返回值 被拦截的类包名或方法(方法参数)"/>
<aop:aspect id="aspect别名" ref="自定义的拦截对象名称">
<aop:before pointcut-ref="point别名" method="自定义拦截对象中实施切入的方法名"/>
</aop:aspect>
</aop:config>
pointcut 表达式
3:基于annoation:
主要是利用org.aspectj.lang.annotation包下的Before,AfterReturning,Around,Aspect等类来实现在自定义类中,通过在类声明前加(@Aspect)表明是继承advice,并在指定的方法中前声明pointcut表达式,在 context.xml中配置<aop:aspectj-autoproxy/>,这样,在容器加载bean后,Spring就会自动取得 Annotation信息,进行代理对象建立等
[/code]
对Spring AOP中三种实现方式的总结
原创mb644638dfa963e 博主文章分类:spring ©著作权
©著作权归作者所有:来自51CTO博客作者mb644638dfa963e的原创作品,请联系作者获取转载授权,否则将追究法律责任
提问和评论都可以,用心的回复会被更多人看到
评论
发布评论
相关文章
-
MySQL中三种表的删除方式
TRUNCATE TABLE语句用于快速删除表中的所有行,但保留表的结构和定义。TRUNCATE TABLE语句比DELETE语句更快,
mysql 数据库 触发器 二进制日志 回滚 -
MyBatis中三种分页查询方式
文章目
MyBatis -
.net中三种Timer使用总结
<br />最近正好做一个WEB中定期执行的程序,而.NET中有3个不同的定时器。所以正好研究研究。这3个定时器分别是:r <br /><br />//3.
timer .net object windows button