- 浏览: 932057 次
- 性别:
- 来自: 北京
文章分类
- 全部博客 (251)
- WebService (17)
- IBatis (22)
- Hibernate (1)
- SpringMVC - 基础篇 (32)
- Spring (15)
- Java (11)
- JVM及调优 - 基础篇 (4)
- 集群 (14)
- 数据库 (17)
- WebSphere (5)
- 多线程 (4)
- 集合、容器 (2)
- DB Pool (1)
- Power Designer (5)
- Maven基础 (5)
- JS (14)
- WEB 前端 (5)
- 实用小工具 (17)
- 社会、人 (2)
- 乱七八糟 (18)
- ASM&CGLIB - 基础篇 (12)
- 缓存 (1)
- 性能 (1)
- 设计之殇 (1)
- 分布式事务 (1)
- 单点登录 (11)
- 分布式 Session (4)
- Memcached - 基础篇 (6)
最新评论
-
一笑_奈何:
楼主写的还真行不错。
扫盲贴 - J2EE集群之JNDI集群实现 -
xuezhongyu01:
博主写的很详细,但最后还是没明白,最后调用BasicDataS ...
Spring中的destroy-method方法 -
Mr梁:
commons-fileupload.jar commons- ...
SpringMVC 中文件上传 MultipartResolver -
Eywa:
总结的很不错
ORACLE CASE WHEN 及 SELECT CASE WHEN的用法 -
TryRelax:
fastjson 比 jackson 好用吧?
Spring MVC Jackson DateFormat
三 AOP的实现方式---Proxy
Spring默认使用J2SE动态代理来作为AOP的代理,故对于代理接口而言用Proxy就可以执行。
JDKProxyFactory.java
package aop;
import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;
import service.impl.PersonServiceBean;
public class JDKProxyFactory implements InvocationHandler {
private Object targetObject;
public Object creatProxyObject(Object targetObject) {
this.targetObject = targetObject;
//创建代理对象 使用Proxy
return Proxy.newProxyInstance(this.targetObject.getClass().getClassLoader(),
this.targetObject.getClass().getInterfaces(),
this);
}
public Object invoke(Object proxy, Method method, Object[] args)
throws Throwable {
// TODO Auto-generated method stub
PersonServiceBean personServiceBean = (PersonServiceBean)this.targetObject;
Object result = null;
if(personServiceBean.getUser()!=null){
result = method.invoke(targetObject, args);
}
else {
System.out.println("你无权进行此操作");
}
return result;
}
}
四 AOP的实现方式---CGLib
如果是一个业务对象没有实现接口,在这种情况下,我们实现的解决方案------使用CGLib来代理。
CGlibProxyFactory.java
package aop;
import java.lang.reflect.Method;
import service.impl.PersonServiceBean;
import net.sf.cglib.proxy.Enhancer;
import net.sf.cglib.proxy.MethodInterceptor;
import net.sf.cglib.proxy.MethodProxy;
public class CGlibProxyFactory implements MethodInterceptor {
private Object targetObject; //代理的目标对象
public Object createProxyObjext(Object targeObject) {
this.targetObject = targeObject;
Enhancer enhancer = new Enhancer(); //创建代理对象
enhancer.setSuperclass(this.targetObject.getClass());//设置此类的父类 非final修饰符的所有方法
enhancer.setCallback(this);//设置回调函数,用对象本身。必须实现接口MehtodInterceptor
return enhancer.create(); //返回创建的代理对象
}
/**
* 执行了上面的回调,接着执行回调函数interceptor.
* proxy:代理对象本身。method:被拦截的方法。
* args: 方法的输入参数。methodProxy:方法的代理对对象。
*/
public Object intercept(Object proxy, Method method, Object[] args,
MethodProxy methodProxy) throws Throwable {
// TODO Auto-generated method stub
PersonServiceBean personServiceBean = (PersonServiceBean) this.targetObject;
Object result = null;
if (personServiceBean.getUser() != null) {
result = methodProxy.invoke(targetObject, args);//委派给代理对象targetObject
}
else{
System.out.println(" 你无权进行此操作!!!");
}
return result;
}
}
单元测试类
package junit.test;
import org.junit.BeforeClass;
import org.junit.Test;
import service.impl.PersonServiceBean;
import aop.CGlibProxyFactory;
public class JunitProxyText {
@BeforeClass
public static void setUpBeforeClass() throws Exception {
}
// @Test
// public void jdkproxyTest(){
// JDKProxyFactory factory = new JDKProxyFactory();
// PersonService personService = (PersonService)factory.creatProxyObject(new PersonServiceBean());
// personService.save("111");
// }
@Test
public void cglibproxyTest(){
CGlibProxyFactory factory = new CGlibProxyFactory();
PersonServiceBean personServiceBean = (PersonServiceBean)factory.createProxyObjext(new PersonServiceBean("xxx"));
personServiceBean.save("222");
}
}
---------------------------------------------------------------------------------------------------------------------------
转载http://zywang.iteye.com/blog/974226
第一种配置方法:使用@AspectJ标签
- 在配置文件中添加<aop:aspectj-autoproxy/>注解
- 创建一个Java文件,使用@Aspect注解修饰该类
- 创建一个方法,使用@Before、@After、@Around等进行修饰,在注解中写上切入点的表达式
说明:上述Java文件创建好后,需要将其在Spring的容器中进行声明,可以在配置文件中定义<bean/>节点,也可以使用@Component组件进行修饰
示例:
- import org.aspectj.lang.ProceedingJoinPoint;
- import org.aspectj.lang.annotation.After;
- import org.aspectj.lang.annotation.AfterThrowing;
- import org.aspectj.lang.annotation.Around;
- import org.aspectj.lang.annotation.Aspect;
- import org.aspectj.lang.annotation.Before;
- import org.springframework.stereotype.Component;
- /**
- * 基于注解的AOP日志示例
- * @author ZYWANG 2011-3-24
- */
- @Component
- @Aspect
- public class AopLog {
- //方法执行前调用
- @Before("execution (* com.zywang.services.impl.*.*(..))")
- public void before() {
- System.out.println("before");
- }
- //方法执行后调用
- @After("execution (* com.zywang.services.impl.*.*(..))")
- public void after() {
- System.out.println("after");
- }
- //方法执行的前后调用
- @Around("execution (* com.zywang.services.impl.*.*(..))")
- public Object around(ProceedingJoinPoint point) throws Throwable{
- System.out.println("begin around");
- Object object = point.proceed();
- System.out.println("end around");
- return object;
- }
- //方法运行出现异常时调用
- @AfterThrowing(pointcut = "execution (* com.zywang.services.impl.*.*(..))",throwing = "ex")
- public void afterThrowing(Exception ex){
- System.out.println("afterThrowing");
- System.out.println(ex);
- }
- }
import org.aspectj.lang.ProceedingJoinPoint; import org.aspectj.lang.annotation.After; import org.aspectj.lang.annotation.AfterThrowing; import org.aspectj.lang.annotation.Around; import org.aspectj.lang.annotation.Aspect; import org.aspectj.lang.annotation.Before; import org.springframework.stereotype.Component; /** * 基于注解的AOP日志示例 * @author ZYWANG 2011-3-24 */ @Component @Aspect public class AopLog { //方法执行前调用 @Before("execution (* com.zywang.services.impl.*.*(..))") public void before() { System.out.println("before"); } //方法执行后调用 @After("execution (* com.zywang.services.impl.*.*(..))") public void after() { System.out.println("after"); } //方法执行的前后调用 @Around("execution (* com.zywang.services.impl.*.*(..))") public Object around(ProceedingJoinPoint point) throws Throwable{ System.out.println("begin around"); Object object = point.proceed(); System.out.println("end around"); return object; } //方法运行出现异常时调用 @AfterThrowing(pointcut = "execution (* com.zywang.services.impl.*.*(..))",throwing = "ex") public void afterThrowing(Exception ex){ System.out.println("afterThrowing"); System.out.println(ex); } }
上面这段代码中多次使用了重复的切入点,这种情况下,可以使用@Pointcut标注,来修改一个切入点方法(这个方法不需要参数和方法体),然后就可以在@Before等标注中引用该方法作为切入点,示例如下:
- import org.aspectj.lang.ProceedingJoinPoint;
- import org.aspectj.lang.annotation.Around;
- import org.aspectj.lang.annotation.Aspect;
- import org.aspectj.lang.annotation.Before;
- import org.aspectj.lang.annotation.Pointcut;
- import org.springframework.stereotype.Component;
- /**
- * 基于注解的AOP日志示例
- * @author ZYWANG 2011-3-24
- */
- @Component
- @Aspect
- public class AopLog {
- @Pointcut("execution (* com.iflysse.school.services.impl.*.*(..))")
- public void pointcut(){}
- //方法执行前调用
- @Before("pointcut()")
- public void before() {
- System.out.println("before");
- }
- //方法执行的前后调用
- @Around("pointcut()")
- public Object around(ProceedingJoinPoint point) throws Throwable{
- System.out.println("begin around");
- Object object = point.proceed();
- System.out.println("end around");
- return object;
- }
- }
import org.aspectj.lang.ProceedingJoinPoint; import org.aspectj.lang.annotation.Around; import org.aspectj.lang.annotation.Aspect; import org.aspectj.lang.annotation.Before; import org.aspectj.lang.annotation.Pointcut; import org.springframework.stereotype.Component; /** * 基于注解的AOP日志示例 * @author ZYWANG 2011-3-24 */ @Component @Aspect public class AopLog { @Pointcut("execution (* com.iflysse.school.services.impl.*.*(..))") public void pointcut(){} //方法执行前调用 @Before("pointcut()") public void before() { System.out.println("before"); } //方法执行的前后调用 @Around("pointcut()") public Object around(ProceedingJoinPoint point) throws Throwable{ System.out.println("begin around"); Object object = point.proceed(); System.out.println("end around"); return object; } }
第二种配置方法:基于配置文件的配置
- 创建一个Java文件,并指定一个用于执行拦截的方法,该方法可以有0个或多个参数
- 在Spring配置文件中注册该Java类为一个Bean
- 使用<aop:config/>、<aop:aspect/>等标签进行配置
示例:
Java文件
- import org.aspectj.lang.ProceedingJoinPoint;
- /**
- * 基于配置文件的AOP日志示例
- * @author ZYWANG 2011-3-24
- */
- public class AopLog {
- //方法执行的前后调用
- public Object runOnAround(ProceedingJoinPoint point) throws Throwable{
- System.out.println("begin around");
- Object object = point.proceed();
- System.out.println("end around");
- return object;
- }
- }
import org.aspectj.lang.ProceedingJoinPoint; /** * 基于配置文件的AOP日志示例 * @author ZYWANG 2011-3-24 */ public class AopLog { //方法执行的前后调用 public Object runOnAround(ProceedingJoinPoint point) throws Throwable{ System.out.println("begin around"); Object object = point.proceed(); System.out.println("end around"); return object; } }
Spring配置文件
- <bean id="aopLog" class="com.iflysse.school.aop.AopLog"></bean>
- <aop:config>
- <aop:aspect ref="aopLog">
- <aop:around method="runOnAround" pointcut="execution (* com.zywang.services.impl.*.*(..))"/>
- </aop:aspect>
- </aop:config>
<bean id="aopLog" class="com.iflysse.school.aop.AopLog"></bean> <aop:config> <aop:aspect ref="aopLog"> <aop:around method="runOnAround" pointcut="execution (* com.zywang.services.impl.*.*(..))"/> </aop:aspect> </aop:config>
注意:上面这个示例使用的是around方式的拦截,该方法要求Java类中的方法有一个ProceedingJoinPoint类型的参数
使用第二种方式的AOP配置,在Eclipse(有SpringIDE插件)中被拦截到的方法中有标识显示
以上配置基于Spring 3.0.5 进行设置,参考其《Reference Documentation》
发表评论
-
properties 文件 属性值换行
2013-09-24 16:33 2199在项目开发中遇到属性文件propertie ... -
扩展PropertyPlaceholderConfigurer对prop文件中的属性加密
2013-09-24 13:53 7150转载:http://my.oschina.net/noah ... -
精通有状态vs无状态(Stateful vs Stateless)—Immutable模式之姐妹篇
2013-09-10 18:06 2227今天给别人解释 Stateful vs Stateless ... -
Spring的DTD验证
2013-03-28 15:45 3818转载:http://a123159521.iteye. ... -
用spring annotation声明的bean,当打包在jar中时,无法被扫描到
2012-10-16 16:33 1270我们项目是由N个工程组成的,外围工程是web工程,内部的工程打 ... -
what’s new in spring 3
2012-10-15 21:35 1228spring3发布已经很久了,但现在为止还不太清楚spring ... -
利用AbstractRoutingDataSource实现动态数据源切换(Spring+Ibatis)
2012-10-14 15:49 3545Spring+Ibatis 与 Spring+Hibernat ... -
利用AbstractRoutingDataSource实现动态数据源切换 (二、Spring+Hibernate)
2012-10-14 13:55 2815用spring 的AbstractRoutingData ... -
利用AbstractRoutingDataSource实现动态数据源切换 (一、Spring+Hibernate)
2012-10-14 13:26 23475在Spring 2.0.1中引入了AbstractR ... -
Spring中的destroy-method方法
2012-05-20 12:29 22084转载:http://technoboy.iteye.com/b ... -
Spring事务(一)
2012-02-26 17:48 988一、Spring中定义了5中不同的事务隔离级别 1 ... -
Spring容器启动过程
2011-09-17 22:58 1833一、一切从手动启动IoC ... -
Spring AOP
2011-09-03 15:35 1440前段时间使用AOP做日志拦截,由于很长时间没有使用过 ... -
Web开发中获取Spring的ApplicationContext的几种方式
2011-08-24 21:49 11981在 WEB 开发中,获取到由 Spring 进行管理的某些 B ...
相关推荐
Spring框架提供了强大的AOP支持,可以方便地定义切入点(Pointcut)和通知(Advice)。 4. **操作日志**: 操作日志记录了系统中的关键事件,有助于排查问题和审计。在文件上传和下载中,日志应包含用户信息、...
首先,Spring框架是Java领域广泛使用的轻量级应用框架,其依赖注入(Dependency Injection,DI)和面向切面编程(Aspect-Oriented Programming,AOP)特性使得代码更加模块化和易于维护。在本软件中,Spring作为核心...
总结来说,"Struts2.Hibernate3.2.Spring2.0整合续一"这个主题主要探讨了如何将这三个强大的框架结合在一起,构建高效、灵活的J2EE应用程序。通过对每个框架的理解和整合技巧的掌握,开发者可以构建出满足复杂业务...
Spring作为轻量级的应用框架,提供了强大的依赖注入(DI)和面向切面编程(AOP)功能,而Hibernate则是一个优秀的对象关系映射(ORM)框架,简化了数据库操作。下面将详细介绍这两个框架在构建网上支付系统中的作用...
在"浪曦原创"的教程中,"浪曦OA与工作流系统 第3讲 Struts2+Hibernate3.2+Spring2.0整合续二(风中叶)"很可能是对这一整合过程的深入讲解。通常,整合过程包括以下步骤: 1. 引入相关库:在项目中添加Struts2、...
Spring框架则是一个全面的企业级应用开发框架,它的核心特性包括依赖注入(DI)和面向切面编程(AOP)。依赖注入帮助解耦组件,使得代码更易于测试和维护。Spring还提供了对事务管理、数据访问、Web应用的支持,以及...
Spring框架是Java EE开发中的核心组件,它提供了依赖注入(Dependency Injection, DI)和面向切面编程(Aspect-Oriented Programming, AOP)等关键功能,简化了应用的构建和管理。在本项目中,Spring可能用于管理...
在IT行业中,构建大型企业级应用时,常常会采用MVC(Model-...而提供的文件"A111]整合Struts + Spring + Hibernate续.exe"可能是一个关于这个整合过程的教程或者示例应用,"src"目录则包含了源代码,供开发者参考学习。
3. **业务逻辑层**:选择了Spring框架,Spring是一个全面的后端开发框架,提供了依赖注入(DI)、面向切面编程(AOP)、事务管理等功能,增强了系统的灵活性和可测试性。 4. **数据库**:采用Oracle11g作为数据存储...
3. **Spring3**:Spring框架是Java企业级应用的核心组件,提供了依赖注入(DI)和面向切面编程(AOP)等功能。在自行车租赁系统中,Spring3管理整个应用的生命周期,包括Bean的创建、配置和装配,同时通过AOP处理...
Spring 是一个全面的企业级应用框架,提供了依赖注入、AOP(面向切面编程)等功能,用于简化应用程序的开发和管理;Hibernate 是一个 ORM(对象关系映射)框架,用于在 Java 应用程序中处理数据库操作。 这个...
Spring是一个全面的后端开发框架,它提供依赖注入(DI)和面向切面编程(AOP)等功能。在SSH配置中,Spring主要负责管理应用程序的bean,包括Struts2的动作类、Hibernate的SessionFactory以及业务逻辑组件等。配置...
3. **租赁业务**:处理租赁申请、续租、退租等业务,涉及到事务管理,Spring AOP可以用来处理异常并回滚事务。 4. **支付管理**:集成第三方支付接口,处理租金支付,可能需要与Spring MVC配合处理HTTP请求和响应。 ...
此外,Spring的AOP功能可以用于实现权限控制,确保只有授权的用户才能访问和操作文件。 在实现网络硬盘的过程中,还需要考虑以下关键知识点: 1. 用户认证与授权:为了保护用户数据的安全,系统应提供用户注册、...
1. **Spring框架**:Spring 是一个轻量级的应用框架,它的核心特性包括 IoC (Inversion of Control) 控制反转和 AOP (Aspect Oriented Programming) 面向切面编程。Spring 提供了对 Bean 的生命周期管理,以及事务...
Spring框架作为核心的依赖注入(DI)和面向切面编程(AOP)容器,负责管理整个应用的组件。它整合了Struts 2和Hibernate,使得两者之间的交互更加流畅。Spring的事务管理功能确保了数据操作的一致性,而其AOP特性则...
Struts提供了MVC(Model-View-Controller)架构模式,Spring为应用提供依赖注入(DI)和面向切面编程(AOP),而Hibernate则是持久层框架,负责数据库操作。在本文中,我们将深入探讨如何使用这三个框架实现文件的...
- `spring-aop.jar`: 支持 AOP 面向切面编程,可以用于声明式事务管理、日志记录、性能监控等场景。 - `spring-web.jar` 和 `spring-webmvc.jar`: `spring-web` 提供了 Servlet API 和 HTTP 相关的支持,`spring-...