`
kidiaoer
  • 浏览: 824781 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
文章分类
社区版块
存档分类
最新评论

Spring AOP总结

阅读更多
   Spring AOP总结
 
 
   Spring AOP(Aspect Oriented Programming)
  
   应用程序通常包含两种代码:一是核心业务代码,一是和业务关系不大的代码如日志、事物处理等。
   AOP的思想就是使这两种代码分离,从而降低了两种代码的偶合性,达到了易于重用和维护的目的。
   AOP和OOP:
   在AOP里,每个关注点的实现并不知道是否有其他关注点关注它,这是AOP和OOP的主要区别,
   在AOP里组合的流向是从横切关注点到主关注点,在OOP中组合流向是从主关注点到横切关注点。
   AOP和OOP所关注的对象不同,AOP是OOP有益的补充,不是对立面。
  
   AOP的3个关键概念:
   1:切入点:(PiontCut)
     连接点(Jion piont):是指程序运行中的某个阶段,如方法的调用、异常的抛出等。
     PiontCut就是Jion piont点的集合,它是程序中需要注入的Advice的集合。指明Advice
     在什么 条件下才被触发。
   2:通知(Advice):
          某个连接点采用的处理逻辑,也就是向连接点注入的代码。
   3:Advisor
      是PiontCut和Advice的配置器,它包含PiontCut和Advice,是把Advice注入到PiontCut位置的代码。


   Spring 的3种切入点的实现:
   1:静态切入点:
     静态切入点只限于给定的方法和目标类。不考虑方法的参数。
   2:动态切入点:
     动态切入点不仅限于给定的方法和目标类,还可以指定方法的参数。
     动态切入点有很大的性能损耗,一般很少使用。
   3:自定义切入点:
    正在发展
   
   
   Spring 的通知:
   1:Interception Around通知
  
    Interception Around在Jion Point的前后执行。实现Interception Around通知要实现
    MethodInterceptor接口,示例代码如下:
(1)Logger logger=Logger.getLogger(this.getClass().getName());

public Object invoke(MethodInvocation arg0) throws Throwable {
   // TODO Auto-generated method stub
   logger.log(Level.INFO,arg0.getArguments()[0]+"开始审核数据:");
   Object result=arg0.proceed();
   logger.log(Level.INFO,arg0.getArguments()[0]+"审核数据结束!");
  
   return result;
}

(2)
   /* public class LoginInterceptor implements MethodInterceptor{
     public Object invoke(MenthodInvocation invocation) throws Throwable{
      System.out.println("开始审核数据");
      Object result = invocation.proceed();
      System.out.println("审核数据结束");
      return result;
     }
    }*/

   2:Before通知
(1)通过log4j.properties实现
Logger logger=Logger.getLogger(this.getClass().getName());

public void before(Method arg0, Object[] arg1, Object arg2)
    throws Throwable {
   // TODO Auto-generated method stub
   logger.log(Level.INFO,arg1[0]+"开始数据操作:");

}
   (2):
      Before通知在JiontPoint的前执行。实现Befored通知要实现
    MethodBeforeAdvice接口,示例代码如下:
    public class LoginBeforeAdvice implements MethodBeforeAdvice{
     public void before(Menthod m,Object [] atgs,Object target) throws Throwable{
      System.out.println("开始审核数据");
     }
    }
   
   
   3:After Return 通知
  
    After Return通知在JiontPoint后执行。实现After Returnd通知要实现
    AfterReturningAdvice接口,示例代码如下:
    public class LoginAfterAdvice implements AfterReturningAdvice{
     public void afterReturning(Method m,Object [] atgs,Object target) throws Throwable{
      System.out.println("审核数据结束");
     }
    }
  
   4:Throw通知
(1)Logger logger=Logger.getLogger(this.getClass().getName());
public void afterThrowing(Method arg1, Object[] arg2,Object arg3,Throwable subclass ) throws Throwable{
   System.out.println(arg2[0]+"审核数据异常");
}
  
    Throw通知在JiontPoint抛出异常时执行。实现Throw通知要实现
    ThrowsAdvice接口,示例代码如下:
    public class LoginThrowAdvice implements ThrowsAdvice{
     public void afterThrowing(Method arg1, RemoteException ex) throws Throwable{
      System.out.println("审核数据异常");
     }
    }
  
   5:Introduction 通知
  
   Introduction通知在JiontPoint 调用完毕后执行。实现Introduction通知要实现
    IntroductionAdvisor接口和IntroductionInterceptor接口。
  
用ProxyFactoryBean创建AOP代理
      使用org.springfamework.aop.framework.ProxyFactoryBean是创建AOP代理的基本方式。
  
   1:使用ProxyFactoryBean代理目标类中的所有方法(参考代码:workspace20070228\SpringAOP1)
    示例代码:
    <beans>
    <bean id="log" class="logAround"/>
    <bean id="logBefore" class="logBefore"/>
    <bean id="logAfter" class="logAfter"/>
    <bean id="logThrow" class="logThrow"/>
    <bean id="timebook" class="TimeBook"/>
    <!-设定代理类-->
    <bean id="logProxy" class ="org.springframework.aop.framework.ProxyFactoryBean">
    <!--代理的是接口-->
    <property name="proxyInterfaces">
    <value>TimeBookInterface</value>
    </property>
      <!--要代理的目标类-->
    <property name="target">
    <ref bean="timebook"/>
    </property>
    <!--程序中的Advice-->
    <property name="interceptorNames">
    <list>
    <value>logBefore</value>
    <value>logAfter</value>
    <value>logThrow</value>
    </list>
    </property>
    </bean>
    </beans>
  
  
   2:使用ProxyFactoryBean代理目标类中的指定方法
  
    示例代码:
    <beans>
    <bean id="log" class="logAround"/>
    <bean id="logBefore" class="logBefore"/>
    <bean id="logAfter" class="logAfter"/>
    <bean id="logThrow" class="logThrow"/>
    <bean id="timebook" class="TimeBook"/>
    <!--代理目标类的指定方法-->
    <bean id ="logAdvisor" class="org.springframework.aop.support.RegexpMethodPointcutAdvisor">
    <property name="advice">
    <ref bean="log"/>
    </property>
    <!--指定要代理的方法-->
    <property name="patterns">
    <value>.*doCheck.*</value>
    </property>
    </bean>
    <!-设定代理类-->
    <bean id="logProxy" class ="org.springframework.aop.framework.ProxyFactoryBean">
   
      <!--要代理的目标类-->
    <property name="target">
    <ref bean="timebook"/>
    </property>
    <!--程序中的Advice-->
    <property name="interceptorNames">
    <list>
    <value>logAdvisor</value>
    </list>
    </property>
    </bean>
    </beans>
   
    ---------------------------------------------------------
   
   正则表达式:
   1:.表示可以匹配任何一个字符
   2:[]表示只有[]里指定的字符才能匹配
   3:*表示匹配次数
   4:?表示可以匹配1或0次
   5:\是正则表达式的连接符
  
   ---------------------------------------------------------------
   Spring 中两种AOP代理方式
   1:动态代理
   动态代理是指代理的是接口,Spring默认的是动态代理
   2:CGLIB代理
   <beans>
   <bean id="log" class="logAround"/>
   <bean id="logBefore" class="logBefore"/>
   <bean id="logAfter" class="logAfter"/>
   <bean id="logThrow" class="logThrow"/>
   <bean id="timebook" class="TimeBook"/>
   <bean id="logProxy" class ="org.springframework.aop.framework.ProxyFactoryBean">
   <property name="proxyTargetClass">
   <value>true</value>
   </property>
   <property name="target">
   <ref bean="timebook"/>
   </property>
   <property name="interceptorNames">
   <list>
   <value>logBefore</value>
   <value>logAfter</value>
   <value>logThrow</value>
   </list>
   </property>
   </bean>
   </beans>
  
-----------------------------------------------------------------------
Spring 中的自动代理方式

自动代理可以跨越多个类,不管哪个类中的方法只要符合要求都可以代理
<beans>
<bean id="log" class="logAround"/>
<bean id="logBefore" class="logBefore"/>
<bean id="logAfter" class="logAfter"/>
<bean id="logThrow" class="logThrow"/>
<bean id="timebook" class="TimeBook"/>
<bean id="timework" class="TimeWork"/>
<!--使用自动代理-->
<bean id="autoProxy" class ="org.springframework.aop.framework.autoproxy.DefaultAdvisorAutoProxyCreator"/>
<bean id="logBeforAdvisor" class="org.springframework.aop.support.RegexpMethodPointcutAdvisor">
<property name="advice">
<ref bean="logBefore"/>
</property>
<property name="patterns">
<value>.*do.*</value>
</property>
</bean>
</beans>

------------------------------------------------------------
Spring中的事务处理

   事务处理是由多个步骤组成,这些步骤之间有一定的逻辑关系,作为一个整体的操作过程,所有的步骤必须同时成功或失败。
   1:提交 当所有的操作步骤都被完整执行后,称为该事物被提交。
   2:回滚 由于某个操作失败,导致所有的步骤都没被提交则事物必须回滚,回到事物执行前的状态。
  
   事务的特性:
   ACID:原子性(Atomicity)一致性(Consistency)隔离性(Isolation)持久性(Durablity)
  
   Spring中的事务处理是基于动态AOP机制的实现。
  
   1:编程式事务处理:
  
   spring 提供的TransactionTemplate能够以编程的方式实现事务控制。
  
   HelloADO.java:
    private DataSource dataSource;
    private PlatformTransactionManager transactionManager;
    public int create(String msg){
    DefaultTransactionDefinition def = new DefaultTransactionDefinition();
    TransactionStatus status = transactionManager.getTransaction(def);
  
    try{
     JdbcTemplate jt = new JdbcTemplate(dataSource);
     int i=jt.update("insert into st(name,password) values('zz','zz')");
     return i;
    }catch (Exception e){
     transactionManager.rollback(status);
     return 0;
    }
    finally {
     transactionManager.commit(status);
    }
    }
   applicationContext.xml
  
    <beans>
    <bean id ="dataSource" class ="org.springframework.jdbc.datasource.DriverManagerDataSource">
    <property name="driverClassName">
    <value>com.mysql.jdbc.Driver</value>
    </property>
    <property name="url">
    <value>jdbc:mysql://localhost:3306/newdb</value>
    </property>
    <property name="username">
    <value>root</value>
    </property>
    <property name="password">
    <value>lxl</value>
    </property>
    </bean>
    <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
    <property name="dataSource">
    <ref bean="dataSource"/>
    </property>
    </bean>
    <bean id="helloDAO" class ="HelloDAO">
    <property name="dataSource">
    <ref bean="dataSource"/>
    </property>
    <property name="transactionManager">
    <ref bean="transactionManager"/>
    </property>
    </bean>
    </beans>
  
   2:声明式事务处理:
  
   HelloADO.java:
  
    public class HelloDAO {
    private DataSource dataSource ;
    private JdbcTemplate jdbcTemplate;
    public void setDataSource(DataSource dataSource) {
     this.dataSource = dataSource;
     jdbcTemplate = new JdbcTemplate(dataSource);
    }
    public void create(String name){
     jdbcTemplate.update("insert into st(name,password)values('lxl','lxl')");
    }
    }
   applicationContext.xml
    <beans>
    <bean id ="dataSource" class ="org.springframework.jdbc.datasource.DriverManagerDataSource">
    <property name="driverClassName">
    <value>com.mysql.jdbc.Driver</value>
    </property>
    <property name="url">
    <value>jdbc:mysql://localhost:3306/newdb</value>
    </property>
    <property name="username">
    <value>root</value>
    </property>
    <property name="password">
    <value>lxl</value>
    </property>
    </bean>
    <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
    <property name="dataSource">
    <ref bean="dataSource"/>
    </property>
    </bean>
    <bean id="helloDAO" class ="HelloDAO">
    <property name="dataSource">
    <ref bean="dataSource"/>
    </property>
    </bean>
    <!-- 声明式事务处理-->
    <bean id="helloDAOProxy" class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean">
    <property name="transactionManager">
    <ref bean="transactionManager"/>
    </property>
    <property name="target">
    <ref bean="helloDAO"/>
    </property>
    <property name="transactionAttributes">
    <props>
    <!-- 对create方法进行事务管理,PROPAGATION_REQUIRED表示如果没有事务就新建一个事务-->
    <prop key="create*">PROPAGATION_REQUIRED</prop>
    </props>
    </property>
    </bean>  
    </beans>
	
分享到:
评论

相关推荐

    Spring AOP完整例子

    总结一下,Spring AOP提供了一种优雅的方式来处理系统的横切关注点,如日志记录、事务管理或性能监控。通过定义切点、创建切面和配置通知,我们可以实现代码的解耦,提高可维护性和复用性。这个例子提供了学习Spring...

    Spring AOP面向方面编程原理:AOP概念

    ### Spring AOP面向方面编程原理:AOP概念详解 #### 一、引言 随着软件系统的日益复杂,传统的面向对象编程(OOP)逐渐暴露出难以应对某些横切关注点(cross-cutting concerns)的问题。为了解决这一挑战,面向方面编程...

    springAop的配置实现

    **Spring AOP 配置实现详解** Spring AOP(Aspect Oriented Programming,面向切面编程)是Spring框架的重要组成部分,它允许我们通过分离关注点来简化应用程序的开发。在传统的面向对象编程中,业务逻辑与日志记录...

    spring-aop-jar

    总结起来,"spring-aop-jar"涉及了Spring框架中的面向切面编程模块,包括Spring AOP和AspectJ的集成。通过理解和熟练使用这些组件,开发者可以有效地解耦关注点,提高代码的可维护性和可扩展性。在实际项目中,结合...

    Spring AOP IOC源码笔记.pdf

    Spring框架是Java开发中不可...总结,Spring框架的IoC和AOP特性极大地简化了Java开发,通过依赖注入解耦了组件,通过面向切面编程解决了共性问题。理解并熟练掌握这些概念和机制,对于提升开发效率和代码质量至关重要。

    spring AOP 理论知识点总结.wps

    spring AOP 理论知识点总结.wpsspring AOP 理论知识点总结.wpsspring AOP 理论知识点总结.wps

    spring aop demo 两种实现方式

    总结来说,Spring AOP提供了一种强大的方式来实现横切关注点,降低了代码的耦合度。无论是通过注解还是配置文件,都能够有效地实现切面的定义和拦截操作。理解并掌握Spring AOP的使用,对于提升Spring框架的应用能力...

    spring aop切面拦截指定类和方法实现流程日志跟踪

    ### Spring AOP 实现流程日志跟踪 #### 一、背景与目的 在现代软件开发过程中,为了确保系统的稳定性和可维护性,通常会引入非功能性的需求来增强应用程序的功能,比如日志记录、安全控制等。这些需求往往不是业务...

    Spring aop 性能监控器

    总结来说,Spring AOP性能监控器通过切面编程实现了对目标方法的无侵入性监控,通过自定义注解、切面类以及配置,我们可以轻松地记录和分析应用程序的性能数据。结合源码学习,可以提升对Spring AOP机制的深入理解。

    SpringAOP.rar_springAOP

    《Spring AOP:面向切面编程的深度解析》 在软件开发中,Spring框架以其强大的功能和灵活性,已经成为Java企业级应用的首选框架之一。其中,Spring AOP(Aspect Oriented Programming,面向切面编程)是Spring框架...

    spring aop 附带测试实例

    在提供的压缩包文件"springAOP"中,可能包含了以下内容: - **切面类(Aspect Class)**:包含切点和通知的Java类,可能使用了`@Aspect`注解。 - **目标类(Target Class)**:被AOP代理的对象,通常包含业务逻辑。...

    spring之AOP(动态代理)

    总结一下,Spring的AOP机制通过JDK动态代理和CGLIB动态代理提供了强大的横切关注点管理功能。开发者可以轻松地定义切面和通知,以实现如日志、事务管理等功能,同时保持核心业务代码的清晰和简洁。在Spring Boot项目...

    spring aop注解版

    总结起来,Spring AOP注解版通过简单易懂的注解,使得面向切面编程变得更加直观和方便。它降低了横切关注点与业务逻辑之间的耦合度,提高了代码的可维护性和复用性。通过合理利用这些注解,开发者可以轻松地实现日志...

    spring aop

    总结来说,这个项目提供了基于Maven和Spring的Web应用实例,展示了如何利用Spring AOP进行切面编程,包括XML配置和注解两种方式。通过学习这个项目,你可以深入理解Spring AOP的工作原理,以及如何在实际项目中有效...

    Spring AOP学习资料(pdf)

    ### Spring AOP 学习资料知识点总结 #### 一、Spring AOP 概念与背景 **Spring AOP**(面向切面编程)是Spring框架中的一个重要组成部分,它通过预定义的切入点来分离关注点,使得核心业务逻辑更加清晰,同时能够...

    Spring AOP 入门作者:廖雪峰

    ### Spring AOP 入门详解 #### 一、Spring AOP 概述 Spring AOP(Aspect Oriented Programming,面向切面编程)是Spring框架的一个关键特性,它为开发者提供了在运行时动态添加代码(即横切关注点或切面)到已有...

    Spring AOP的底层实现技术

    总结来说,Spring AOP通过代理模式和切面编程思想,实现了代码的解耦和模块化,提高了软件的可维护性和可扩展性。了解并熟练掌握Spring AOP的底层实现技术,对于提升开发效率和编写高质量的Java应用程序具有重要意义...

Global site tag (gtag.js) - Google Analytics