需要的Jar包(String3.2)
com.springsource.net.sf.cglib-2.2.0.jar // 作用于cglib方式的动态代理
com.springsource.org.aopalliance-1.0.0.jar
com.springsource.org.aspectj.weaver-1.6.8.RELEASE.jar
spring-aop-3.2.0.RELEASE.jar

五种增强模式

1、前置增强【before】,在业务代码之前执行增强的服务代码

示例代码如下:
AopUtil.java

// 服务类定义                                      
public class AopUtil {                             
    // 增强函数                                    
    public void showLog(){                         
        System.out.println("调用服务类功能成功!");
    }                                              
}

 

Bean.java

// 业务类实现                                          
public class Bean {                                    
    // 具体业务功能实现                                
    public void callBean(){                            
        System.out.println("调用Bean业务类功能成功!");
    }                                                  
}

配置文件 spring.xml

<?xml version="1.0" encoding="UTF-8"?>                                         
<beans                                                                         
    xmlns="http://www.springframework.org/schema/beans"                        
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"                      
    xmlns:aop="http://www.springframework.org/schema/aop"                      
    xsi:schemaLocation="                                                       
            http://www.springframework.org/schema/beans                        
            http://www.springframework.org/schema/beans/spring-beans-2.5.xsd   
                                                                               
10               http://www.springframework.org/schema/aop                         
11                 http://www.springframework.org/schema/aop/spring-aop-3.0.xsd "> 
12                                                                                 
13       <bean id="beanID"  class="aop.xml.Bean" ></bean>                          
14       <bean id="utilID"  class="aop.xml.AopUtil"></bean>                        
15                                                                                 
16       <aop:config proxy-target-class="true">                                    
17           <aop:pointcut expression="execution(public *  *.*(..))" id="pcID"/>   
18                                                                                 
19           <aop:aspect ref="utilID" >                                            
20               <aop:before method="showLog"  pointcut-ref="pcID" />              
21           </aop:aspect>                                                         
22       </aop:config>                                                             
23                                                                                 
24   </beans>

TestSpring.java

// 程序入口                                                          
public class TestSpring {                                            
    public static void main(String[] args) {                         
        ApplicationContext ac = new ClassPathXmlApplicationContext(  
                new String[] { "aop/xml/spring.xml" });              
        Bean bean = (Bean) ac.getBean("beanID");                     
        bean.callBean();                                             
    }                                                                
}

2、后置增强【after】,在业务代码之后执行执行增强的服务代码,与前置增强区别仅在于XML文件中对aop的配置

<aop:config proxy-target-class="true">                                     
        <aop:pointcut expression="execution(public *  *.*(..))" id="pcID"/>
                                                                           
        <aop:aspect ref="utilID" >                                         
            <aop:after method="showLog"  pointcut-ref="pcID" />            
        </aop:aspect>                                                      
</aop:config>

3、正常返回后增强【after-returning】,业务代码正确执行后才会执行服务代码,也就是说若业务代码如果有异常,服务代码就不会执行

<aop:config proxy-target-class="true">                                     
        <aop:pointcut expression="execution(public *  *.*(..))" id="pcID"/>
                                                                           
        <aop:aspect ref="utilID" >                                         
            <aop:after-returning method="showLog"  pointcut-ref="pcID" />  
        </aop:aspect>                                                      
</aop:config>

4、异常后增强【after-throwing】,与after-returning的执行过程相反

<aop:config proxy-target-class="true">                                     
        <aop:pointcut expression="execution(public *  *.*(..))" id="pcID"/>
                                                                           
        <aop:aspect ref="utilID" >                                         
            <aop:after-throwing method="showLog"  pointcut-ref="pcID" />   
        </aop:aspect>                                                      
</aop:config>

5、方法环绕增强【around】

<aop:config proxy-target-class="true">                                            
        <aop:pointcut expression="execution(public *  *.callBean(..))" id="pcID"/>
                                                                                  
        <aop:aspect ref="utilID" >                                                
            <aop:around method="writeLog"  pointcut-ref="pcID" />                 
        </aop:aspect>                                                             
</aop:config>
// 服务类定义
public class AopUtil {
   
    public void writeLog(ProceedingJoinPoint point) throws Throwable{
        System.out.println("调用服务类功能【writeLog】成功!");
        point.proceed();
    }
}

方法环绕增强与前面四种增强的主要区别在于,业务代码调用的控制在服务类的增强函数中 point.proceed()

XML方式配置stringAop总结:
确定动态代理方式JDK还是CGILIB有proxy-target-class属性字段的值确定,false表示采用JDK自带的动态代理,true表示采用 CGLIB动态代理;确定切入点即业务类中实现的业务方法,由属性值aop:pointcut expression确定,id=”pcID”建立业务方法的ID值execution属性值格式:
execution(修饰符 返回值 包名.类名.方法名(参数) 异常),其中修饰符、包名、类名、异常可以省略也支持通配符*,返回类型、方法名、参数不能省略但支持通配符*;
业务方法与服务方法建立关系由aop:aspect配置确定,ref=”utilID”指定服务类对象,
<aop:增强方式 method=增强方法 pointcut-ref=业务方法ID值 />

 

注解方式实现stringAop示范例代码:

spring.xml

<?xml version="1.0" encoding="UTF-8"?>
<beans                                                                                
    xmlns="http://www.springframework.org/schema/beans"                               
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"                             
    xmlns:aop="http://www.springframework.org/schema/aop"                             
    xmlns:context="http://www.springframework.org/schema/context"                     
                                                                                      
    xsi:schemaLocation="                                                              
            http://www.springframework.org/schema/beans                               
10               http://www.springframework.org/schema/beans/spring-beans-2.5.xsd         
11                                                                                        
12               http://www.springframework.org/schema/aop                                
13                 http://www.springframework.org/schema/aop/spring-aop-3.0.xsd           
14                                                                                        
15                 http://www.springframework.org/schema/context                          
16                 http://www.springframework.org/schema/context/spring-context-3.0.xsd" >
17                                                                                        
18       <!-- 打开注解开关, 开关打开后才能解析@符号表示的注解 -->                        
19       <context:annotation-config />                                                    
20       <!-- 扫描指定包下的注解,也就是指定需解析注解的路径 -->                          
21       <context:component-scan base-package="annotation"></context:component-scan>      
22       <!-- 告诉springAop,产生业务类的动态代理对象,并切入到对应服务类方法中 -->        
23       <aop:aspectj-autoproxy/>                                                         
24   </beans>

Bean.java 

// 业务类实现                                              
//@Component表示业务Bean实例化                             
@Component(value="beanID")                                 
public class Bean {                                        
    // 具体业务功能实现,通过@Pointcut注解注册切入点       
    @Pointcut (value="execution(public *  *.callBean(..))")
    public void callBean(){                                
        System.out.println("调用Bean业务类功能成功!");    
    }                                                      
10   }

AopUtil.java

// 服务类定义                                                                 
//@Aspect表示AopUtil为切面,@Component(value="aopUtilID")对AopUtil类进行实例化
@Aspect                                                                       
@Component(value="aopUtilID")                                                 
public class AopUtil {                                                        
    // @Before确定为增强模式为前置增强,value的值表示增强的业务函数           
    @Before (value="annotation.Bean.callBean()")                              
    public void writeLog(){                                                   
        System.out.println("调用服务类功能【writeLog】成功!");               
10       }                                                                        
11  }

TestSpring.java   // 程序入口

public class TestSpring {                                          
    public static void main(String[] args) {                       
        ApplicationContext ac = new ClassPathXmlApplicationContext(
                new String[] { "annotation/spring.xml" });         
        Bean bean = (Bean) ac.getBean("beanID");                   
        bean.callBean();                                           
    }                                                              
}

注解说明:
@Component(value=自定义ID名称)作用于需实例化的类,并将实例化后的类对象加入Bean工厂;
@Aspect 指定作用于springAop中的切面类;
@Before (value="业务方法名")指定springAop中增强模式及需要增强的业务方法,业务方法名需带包名;
@Pointcut (value="execution表达式)") 指定springAop切入点业务方法;
@Resource(name="自定义ID名称")在Bean工厂中查找对应的ID名称对象,并注入到修饰的方法中,例子如下:

private Unit unit;                  
    @Resource(name="unitID")        
    public void setUnit(Unit unit) {
        this.unit = unit;                                  
}

Spring笔记(四)SpingAOP的更多相关文章

  1. Spring笔记四

    Spring-04 1.Spring整合Junit ①导入依赖 <!-- junit --> <dependency> <groupId>junit</gro ...

  2. Spring 笔记 -06- 从 MySQL 建库到 登录验证数据库信息(maven)

    Spring 笔记 -06- 从 MySQL 建库到 登录验证数据库信息(maven) 本篇和 Spring 没有什么关系,只是学习 Spring,必备一些知识,所以放在这里了. 本篇内容: (1)M ...

  3. Spring笔记(6) - Spring的BeanFactoryPostProcessor探究

    一.背景 在说BeanFactoryPostProcessor之前,先来说下BeanPostProcessor,在前文Spring笔记(2) - 生命周期/属性赋值/自动装配及部分源码解析中讲解了Be ...

  4. C#可扩展编程之MEF学习笔记(四):见证奇迹的时刻

    前面三篇讲了MEF的基础和基本到导入导出方法,下面就是见证MEF真正魅力所在的时刻.如果没有看过前面的文章,请到我的博客首页查看. 前面我们都是在一个项目中写了一个类来测试的,但实际开发中,我们往往要 ...

  5. 《MFC游戏开发》笔记四 键盘响应和鼠标响应:让人物动起来

    本系列文章由七十一雾央编写,转载请注明出处. http://blog.csdn.net/u011371356/article/details/9327377 作者:七十一雾央 新浪微博:http:// ...

  6. IOS学习笔记(四)之UITextField和UITextView控件学习

    IOS学习笔记(四)之UITextField和UITextView控件学习(博客地址:http://blog.csdn.net/developer_jiangqq) Author:hmjiangqq ...

  7. java之jvm学习笔记四(安全管理器)

    java之jvm学习笔记四(安全管理器) 前面已经简述了java的安全模型的两个组成部分(类装载器,class文件校验器),接下来学习的是java安全模型的另外一个重要组成部分安全管理器. 安全管理器 ...

  8. Java学习笔记四---打包成双击可运行的jar文件

    写笔记四前的脑回路是这样的: 前面的学习笔记二,提到3个环境变量,其中java_home好理解,就是jdk安装路径:classpath指向类文件的搜索路径:path指向可执行程序的搜索路径.这里的类文 ...

  9. Java加密与解密笔记(四) 高级应用

    术语列表: CA:证书颁发认证机构(Certificate Authority) PEM:隐私增强邮件(Privacy Enhanced Mail),是OpenSSL使用的一种密钥文件. PKI:公钥 ...

随机推荐

  1. 关于return和exit

    关于return和exit 在子进程退出的时候有两种方式,exit和exec族函数,不能使用return,为什么不能用return呢,exit改成return 会出现父子进程又各自重复开始进行. 1. ...

  2. C++引用计数

    简介 引用计数就是对一个对象记录其被引用的次数,其的引用计数可加可减,那什么时候加什么时候减呢?所以引用计数的重点在于在哪里加,在哪里减: 加: 减: 实现 // // Ref.hpp // Ref ...

  3. SmartGit初步使用

    在Git如日中天的今天,我也不免俗的想用Git将业余时间写的代码管理一下. 什么是Git这里不多说,具体见廖雪峰的Git教程,ProGit等详细教程. 我们这里直接上手. 一.下载Git客户端 1.G ...

  4. Oracle的登录操作

    在完美的启动Oracle数据库之后就可以登录数据库了: 1. 首先登录时使用的用户名默认是“SYSTEM”密码是你安装的时候自行设置的. 登录使用的命令是“sqlplus / as sysdba”之后 ...

  5. Ubuntu安装提示Permission Denied

    我用wubi安装ubuntu 显示 permission denied 并要查看日志文件 怎么办啊? 你好,你把你的ISO放到你的Wubi目录下面,也就是把镜像放到你解压好的文件夹里面就可以了呢!! ...

  6. POJ 2942 Knights of the Round Table(双连通分量)

    http://poj.org/problem?id=2942 题意 :n个骑士举行圆桌会议,每次会议应至少3个骑士参加,且相互憎恨的骑士不能坐在圆桌旁的相邻位置.如果意见发生分歧,则需要举手表决,因此 ...

  7. vs2012+cmake+opencv+opencv unable to find a build program corresponding to "Visual Studio 12 Win64". CMAKE_MAKE_PROGRAM is not set

    搜索了下,说什么的都有! 一,提示找不到 cmake-2.8.12.1 的 modles 卸载了cmake后发现 cmd 中的 cmake --version 还是 2.8.11.1 找到是我的cyg ...

  8. Android 使控件各占屏幕的一半

    在xml中将两个要占屏幕一半的控件都加上android:layout_weight="1": 注意:weight只能用在LinearLayout布局中. 在LinearLayout ...

  9. WPF下的一个Socket

    public class Connection { Socket _connection; public Connection(Socket socket) { _connection = socke ...

  10. tcpdump dump 网络流量

    tcpdump dump 网络流量 描述: Tcpdump 打印一个包的内容的描述在一个网络接口 匹配布尔值表达式 它也可以运行使用-w flag, 这样会保存包的数据到一个文件用于后面分析, 使用- ...