- 浏览: 124462 次
- 性别:
- 来自: 深圳
文章分类
最新评论
1
下面看具体的例子:
定义Person接口,声明两个方法
package lee; public interface Person { void info(); void run(); }
具体的实现类
package lee; public class PersonImpl implements Person { private String name; private int age; public void info() { System.out.println("我的名字是:"+name+",今年年龄为:"+age); } public void run() { if(age > 45){ System.out.println("我年老体弱,只能慢跑"); }else{ System.out.println("我年轻体壮,可以快跑"); } } public String getName() { return name; } public void setName(String name) { this.name = name; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } }
下面定义三个拦截器
package lee; import java.lang.reflect.Method; import org.springframework.aop.MethodBeforeAdvice; public class MyBeforeAdvisor implements MethodBeforeAdvice { public void before(Method m, Object[] arg, Object target) throws Throwable { System.out.println("方法调用前..."); System.out.println("下面是方法调用的信息..."); System.out.println("所执行的方法是..."+m); System.out.println("调用方法的参数是..."+arg); System.out.println("目标对象是..."+target); } }
package lee; import org.aopalliance.intercept.MethodInterceptor; import org.aopalliance.intercept.MethodInvocation; public class MyAroundInterceptor implements MethodInterceptor { public Object invoke(MethodInvocation invocation) throws Throwable { System.out.println("调用方法之前:invocation对象:["+invocation+"]"); Object rval = invocation.proceed(); System.out.println("调用结束..."); return rval; } }
package lee; import java.lang.reflect.Method; import org.springframework.aop.AfterReturningAdvice; public class MyAfterAdvisor implements AfterReturningAdvice { public void afterReturning(Object returnValue, Method m, Object[] args, Object target) throws Throwable { System.out.println("方法调用结束..."); System.out.println("目标方法的返回值是:..."+returnValue); System.out.println("目标方法是..."+m); System.out.println("目标方法的参数是..."+args); System.out.println("目标对象是..."+target); } }
spring配置文件
<bean id="personTarget" class="lee.PersonImpl"> <property name="name"> <value>Wawa</value> </property> <property name="age"> <value>51</value> </property> </bean> <bean id="myBeforeAdvisor" class="lee.MyBeforeAdvisor"/> <bean id="myAroundAdvisor" class="lee.MyAroundInterceptor"/> <!-- 正则表达式横切点 --> <bean id="runAdvisor" class="org.springframework.aop.support.RegexpMethodPointcutAdvisor"> <!-- advice属性确定处理bean --> <property name="advice"> <!-- 此处的处理bean定义采用嵌套bean,也可引用容器的另一个bean --> <bean class="lee.MyAfterAdvisor"></bean> </property> <!-- patterns定义正则表达式 --> <property name="patterns"> <list> <!-- 确定正则表达式列表 --> <value>.*run.*</value> </list> </property> </bean> <bean id="person" class="org.springframework.aop.framework.ProxyFactoryBean"> <!-- 定义需代理的接口 --> <property name="proxyInterfaces"> <value>lee.Person</value> </property> <!-- 定义要切入的对象 --> <property name="target"> <ref local="personTarget"/> </property> <!-- 使用以下三个拦截类切入 --> <property name="interceptorNames"> <list> <value>runAdvisor</value> <value>myBeforeAdvisor</value> <value>myAroundAdvisor</value> </list> </property> </bean>
测试类:
package lee; import org.springframework.beans.factory.xml.XmlBeanFactory; import org.springframework.core.io.ClassPathResource; public class BeanTest { public static void main(String[] args) { XmlBeanFactory factory = new XmlBeanFactory(new ClassPathResource("applicationContext.xml")); Person p = (Person)factory.getBean("person"); p.run(); } }
最后打印出
方法调用前... 下面是方法调用的信息... 所执行的方法是...public abstract void lee.Person.run() 调用方法的参数是...[Ljava.lang.Object;@184ec44 目标对象是...lee.PersonImpl@1b383e9 调用方法之前:invocation对象:[ReflectiveMethodInvocation: public abstract void lee.Person.run(); target is of class [lee.PersonImpl]] 我年老体弱,只能慢跑 调用结束... 方法调用结束... 目标方法的返回值是:...null 目标方法是...public abstract void lee.Person.run() 目标方法的参数是...[Ljava.lang.Object;@99681b 目标对象是...lee.PersonImpl@1b383e9
下面再看一个权限校验的例子:
package permission; public interface TestService { void view(); void modify(); }
package permission; public class TestServiceImpl implements TestService { public void modify() { System.out.println("用户修改数据"); } public void view() { System.out.println("用户查看数据"); } }
package permission; public interface TestAction { public void view(); public void modify(); }
package permission; public class TestActionImpl implements TestAction { private TestService ts; public void modify() { ts.modify(); } public void view() { ts.view(); } public void setTs(TestService ts) { this.ts = ts; } }
拦截类,这个类中会进行验权
package permission; import org.aopalliance.intercept.MethodInterceptor; import org.aopalliance.intercept.MethodInvocation; public class AuthorityInterceptor implements MethodInterceptor { private String user; public void setUser(String user) { this.user = user; } public Object invoke(MethodInvocation invocation) throws Throwable { System.out.println("-------------------------"); String methodName = invocation.getMethod().getName(); if(!user.equals("admin") && !user.equals("registedUser")){ System.out.println("你无权执行该方法"); return null; }else if(user.equals("registedUser") && methodName.equals("modify")){ System.out.println("你不是管理员,无法修改数据"); return null; }else { return invocation.proceed(); } } }
spring中的配置文件
<bean id="serviceTarget" class="permission.TestServiceImpl"/> <bean name="authorityInterceptor" class="permission.AuthorityInterceptor"> <property name="user"> <value>registedUser</value> </property> </bean> <bean id="service" class="org.springframework.aop.framework.ProxyFactoryBean"> <property name="proxyInterfaces"> <value>permission.TestService</value> </property> <property name="target"> <ref local="serviceTarget"/> </property> <property name="interceptorNames"> <list> <value>authorityInterceptor</value> </list> </property> </bean> <bean id="testAction" class="permission.TestActionImpl"> <property name="ts"> <ref local="service"/> </property> </bean>
测试类
package permission; import org.springframework.beans.factory.xml.XmlBeanFactory; import org.springframework.core.io.ClassPathResource; public class BeanTest { public static void main(String[] args) { XmlBeanFactory factory = new XmlBeanFactory(new ClassPathResource("applicationContext.xml")); TestAction ta = (TestAction)factory.getBean("testAction"); ta.modify(); ta.view(); } }
结果打印:
------------------------- 你不是管理员,无法修改数据 ------------------------- 用户查看数据
这个例子属于功能增强的概念,将验权功能植入action类中。
如果没有接口,只有具体类应该怎么做?如只有TestServiceImpl类,没有TestService接口,那么应该如何拦截,
可在spring配置文件中将设置一个属性proxyTargetClass,将其值设为true,表示目标类是个具体类,如下粗体所示。
<bean id="service" class="org.springframework.aop.framework.ProxyFactoryBean"> <property name="proxyTargetClass"> <value>true</value> </property> <property name="target"> <ref local="serviceTarget"/> </property> <property name="interceptorNames"> <list> <value>authorityInterceptor</value> </list> </property> </bean>
发表评论
-
spring(5):spring,struts2和hibernate结合
2011-09-25 01:04 974本节主要通过一个小例子来讲解spring,struts,hib ... -
spring(4):hibernate与spring整合
2011-09-23 20:03 903本节主要讲述hibernate与spring整合: 1,首先 ... -
spring(2):struts与spring整合
2011-09-21 16:42 800本节主讲将struts与spring进行整合: 1,新建一个 ... -
spring(1):spring入门,IOC介绍
2011-09-18 15:20 809http://mynote.iteye.com/admin/b ...
相关推荐
赠送jar包:spring-aop-5.0.10.RELEASE.jar; 赠送原API文档:spring-aop-5.0.10.RELEASE-javadoc.jar; 赠送源代码:spring-aop-5.0.10.RELEASE-sources.jar; 赠送Maven依赖信息文件:spring-aop-5.0.10.RELEASE....
3. **配置AOP** - **XML配置**:在Spring的配置文件中,可以使用<aop:config>标签来定义切面,<aop:pointcut>定义切点,<aop:advisor>定义通知,<aop:aspect>将切点和通知关联起来。 - **注解配置**:Spring 2.5...
在本篇博客“Spring基础:AOP编程(4)”中,我们将深入探讨Spring框架中的面向切面编程(Aspect-Oriented Programming,简称AOP),这是一个强大的功能,它允许我们在不修改原有业务代码的情况下,实现对系统中横切...
3. **灵活的通知模型**:Spring AOP提供了多种类型的通知,包括around、before、after returning、after throwing等,使得开发者可以根据实际需求选择最适合的通知类型。 4. **丰富的切入点表达式语言**:Spring ...
spring-aop-6.0.2.jar
spring-aop-1.1.1.jar spring-aop-1.2.6.jar spring-aop-1.2.9.jar spring-aop-2.0.2.jar spring-aop-2.0.6.jar spring-aop-2.0.7.jar spring-aop-2.0.8.jar spring-aop-2.0.jar spring-aop-2.5.1.jar spring-aop-...
赠送jar包:spring-aop-5.2.0.RELEASE.jar; 赠送原API文档:spring-aop-5.2.0.RELEASE-javadoc.jar; 赠送源代码:spring-aop-5.2.0.RELEASE-sources.jar; 赠送Maven依赖信息文件:spring-aop-5.2.0.RELEASE.pom;...
3. AspectJ和Spring AOP的关系 AspectJ是Java社区中广泛使用的AOP框架之一。在Spring框架中,从2.0版本开始支持两种方式来使用AOP:基于AspectJ注解的AOP以及基于XML配置的AOP。 4. 在Spring中启用AspectJ注解支持 ...
Spring AOP(面向切面编程)是Spring框架的重要组成部分,它提供了一种强大的方式来实现横切关注点,如日志、事务管理、性能监控等,而无需侵入业务代码。下面将详细介绍Spring AOP的注解方式和XML配置方式。 ### ...
Spring AOP(面向切面编程)是Spring框架的重要组成部分,它提供了一种模块化和声明式的方式来处理系统中的交叉关注点问题,如日志、事务管理、安全性等。本示例将简要介绍如何在Spring应用中实现AOP,通过实际的...
Spring AOP,全称Aspect-Oriented Programming(面向切面编程),是Spring框架的一个重要模块,它通过提供声明式的方式来实现面向切面编程,从而简化了应用程序的开发和维护。在Spring AOP中,我们无需深入到每个...
Spring是一个轻量级的控制反转(IoC)和面向切面(AOP)的容器框架。Spring AOP:通过配置管理特性,Spring AOP 模块直接将面向方面的编程功能集成到了 Spring 框架中。所以,可以很容易地使 Spring 框架管理的任何对象...
**Spring AOP编程详解** 在Java开发中,Spring框架因其强大的功能和易用性而备受推崇,其中AOP(Aspect-Oriented Programming,面向切面编程)是其核心特性之一。AOP允许开发者将关注点从核心业务逻辑中分离出来,...
Spring AOP(Aspect Oriented Programming,面向切面编程)是Spring框架的重要组成部分,它提供了一种在不修改源代码的情况下,对程序进行功能增强的技术。这个"spring aop jar 包"包含了实现这一功能所需的类和接口,...
赠送jar包:spring-aop-5.0.8.RELEASE.jar; 赠送原API文档:spring-aop-5.0.8.RELEASE-javadoc.jar; 赠送源代码:spring-aop-5.0.8.RELEASE-sources.jar; 赠送Maven依赖信息文件:spring-aop-5.0.8.RELEASE.pom;...
Spring源码最难问题:当Spring AOP遇上循环依赖 Spring源码中最难的问题之一是循环依赖问题,当Spring AOP遇上循环依赖时,该如何解决? Spring通过三级缓存机制解决循环依赖的问题。 在Spring中,bean的实例化...
里面包括4个例子:(1)Spring实现AOP方式之一:基于XML配置的Spring AOP (2)Spring实现AOP方式之二:使用注解配置 Spring AOP (3)Spring AOP : AspectJ Pointcut 切点 (4)Spring AOP : Advice 声明 (通知注解)
SpringAOP Spring AOP(面向方面的编程)用于模块化“横截面”服务。 用一种简单的方式,我们可以说它是一个旨在拦截某些进程的组件,例如,在执行某个方法时,Spring AOP可以审核该执行方法,并在该方法执行...
赠送jar包:spring-aop-5.3.12.jar; 赠送原API文档:spring-aop-5.3.12-javadoc.jar; 赠送源代码:spring-aop-5.3.12-sources.jar; 赠送Maven依赖信息文件:spring-aop-5.3.12.pom; 包含翻译后的API文档:spring...
赠送jar包:spring-aop-5.3.15.jar; 赠送原API文档:spring-aop-5.3.15-javadoc.jar; 赠送源代码:spring-aop-5.3.15-sources.jar; 赠送Maven依赖信息文件:spring-aop-5.3.15.pom; 包含翻译后的API文档:spring...