`

Spring AOP 2

    博客分类:
  • j2ee
阅读更多

<!-- @page { margin: 2cm } P { margin-bottom: 0.21cm } -->

LogBeforeAdvice.java

package com.chapter8.advices;

import java.lang.reflect.Method;

import java.util.Date;

import java.text.SimpleDateFormat;

import java.util.Arrays;

import org.springframework.aop.MethodBeforeAdvice;

 

/**

* 前置通知

*

* @author Administrator

*

*/

public class LogBeforeAdvice implements MethodBeforeAdvice {

/**

* 实现接口中的方法

*

* @param arg0

* 目标方法的名称

* @param arg1

* 被调方法的参数

* @return arg2 被调方法所属的对象实例

*/

public void before(Method arg0, Object[] arg1, Object arg2)

throws Throwable {

// TODO Auto-generated method stub

SimpleDateFormat formate = new SimpleDateFormat("yyyy-MM-dd");

String currentDate = formate.format(new Date());

System.out.println("*****************" + currentDate + " 执行方法 "

+ arg0.getName() + " 参数为: " + Arrays.toString(arg1));

}

 

}

 

LogAroundAdvice.java

package com.chapter8.advices;

import org.aopalliance.intercept.MethodInterceptor;

import org.aopalliance.intercept.MethodInvocation;

/**

* 环绕通知

* @author Administrator

*

*/

public class LogAroundAdvice implements MethodInterceptor {

/**

* 实现接口中的方法

*

* @param method

* 获取一个代理对象,该对象可以调用目标方法。

*/

public Object invoke(MethodInvocation method) throws Throwable {

// TODO Auto-generated method stub

System.out.println("........ aroundAdvice 方法执行之前 ");

Object result = method.proceed();

System.out.println("result = " + result);

System.out.println("........ aroundAdvice 方法执行之后 ");

return result;

}

}

 

测试以上代码:

TestAdvice.java

package com.chapter8.advices;

import org.springframework.context.ApplicationContext;

import org.springframework.context.support.ClassPathXmlApplicationContext;

/**

*

* @author Administrator

* 在本例测试中 BookService 接口中的 buy comment 方法都需要完成日志操作,

* 在系统的其他地方也可能需要日志处理,那么在这里日志已经散落在系统的不同部

* 分了,为了解决系统中所有的日志输出问题,可以把日志输出集中解决。

*

*/

public class TestAdvice {

/**

* @param args

*/

public static void main(String[] args) {

// TODO Auto-generated method stub

ApplicationContext context = new ClassPathXmlApplicationContext (

"advices.xml" );

BookService bookService = (BookService) context.getBean( "bookService" );

bookService.buy( "scott" , "Java" , 100.5);

bookService.comment( "scott" , " 很不错的一本书 " );

bookService.bookOrder();

bookService.bookCustomer();

}

}

advices.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.0.xsd

http://www.springframework.org/schema/aop

http://www.springframework.org/schema/aop/spring-aop-2.0.xsd" >

 

<!-- 完成织入操作, spring 使用代理的方式将方面代码织入到业务对象中 -->

< bean id = "bookService"

class = "org.springframework.aop.framework.ProxyFactoryBean" >

< property name = "proxyInterfaces" >

< value > com.chapter8.advices.BookService </ value >

</ property >

< property name = "interceptorNames" >

< list >

< value > logAdvice </ value >

<!-- 设置通知类型 -->

<!-- 设置后置通知 -->

<!--<value>logAfterAdvice</value>-->

<!-- 设置前置通知 -->

<!--<value>logbeforAdvice</value>-->

<!-- 设置环绕通知 -->

<!--<value>logAroundAdvice</value>-->

</ list >

</ property >

< property name = "target" ref = "bookServiceTarget" ></ property >

</ bean >

 

<!-- 切入点 -->

< bean id = "logAdvice"

class = "org.springframework.aop.support.NameMatchMethodPointcutAdvisor" >

< property name = "mappedNames" >

< list >

<!-- 匹配连接点的规则。通知和一个切入点表达式关联,并在满足这个切入点的连接点上运行 -->

<!-- 指定在 buy 方法上执行通知 -->

< value > buy </ value >

<!-- 指定在所有 book 开始的方法上执行通知 -->

< value > book* </ value >

</ list >

</ property >

< property name = "advice" ref = "logAroundAdvice" ></ property >

</ bean >

 

< bean id = "logbeforAdvice"

class = "com.chapter8.advices.LogBeforeAdvice" >

</ bean >

< bean id = "logAfterAdvice"

class = "com.chapter8.advices.LogAfterAdvice" >

</ bean >

< bean id = "logAroundAdvice"

class = "com.chapter8.advices.LogAroundAdvice" >

</ bean >

 

< bean id = "bookServiceTarget"

class = "com.chapter8.advices.BookServiceImpl" >

</ bean >

 

 

</ beans >

 

 

 

分享到:
评论

相关推荐

    spring aop jar 包

    Spring AOP(Aspect Oriented Programming,面向切面编程)是Spring框架的重要组成部分,它提供了一种在不修改源代码的情况下,对程序进行功能增强的技术。这个"spring aop jar 包"包含了实现这一功能所需的类和接口,...

    Spring AOP 16道面试题及答案.docx

    Spring AOP,全称为Aspect Oriented Programming,是面向切面编程的一种编程范式,它是对传统的面向对象编程(OOP)的一种补充。在OOP中,核心是对象,而在AOP中,核心则是切面。切面是关注点的模块化,即程序中的...

    简单spring aop 例子

    Spring AOP(面向切面编程)是Spring框架的重要组成部分,它提供了一种模块化和声明式的方式来处理系统中的交叉关注点问题,如日志、事务管理、安全性等。本示例将简要介绍如何在Spring应用中实现AOP,通过实际的...

    Spring AOP完整例子

    Spring AOP(面向切面编程)是Spring框架的核心特性之一,它允许开发者在不修改源代码的情况下,通过插入切面来增强或改变程序的行为。在本教程中,我们将深入探讨Spring AOP的不同使用方法,包括定义切点、通知类型...

    spring aop依赖jar包

    现在,我们回到主题——"springaop依赖的jar包"。在Spring 2.5.6版本中,使用Spring AOP通常需要以下核心jar包: - `spring-aop.jar`:这是Spring AOP的核心库,包含了AOP相关的类和接口。 - `spring-beans.jar`:...

    spring-aop.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-...

    Spring Aop四个依赖的Jar包

    Spring AOP,全称Aspect-Oriented Programming(面向切面编程),是Spring框架的一个重要模块,它通过提供声明式的方式来实现面向切面编程,从而简化了应用程序的开发和维护。在Spring AOP中,我们无需深入到每个...

    死磕Spring之AOP篇 - Spring AOP两种代理对象的拦截处理(csdn)————程序.pdf

    Spring AOP 是一种面向切面编程的技术,它允许我们在不修改源代码的情况下,对应用程序的特定部分(如方法调用)进行增强。在 Spring 中,AOP 的实现主要依赖于代理模式,有两种代理方式:JDK 动态代理和 CGLIB 动态...

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

    2. **轻量级**:与一些需要预编译器的AOP框架不同,Spring AOP无需特殊的工具或编译步骤即可使用。这种轻量级的特性使得Spring AOP更易于学习和集成。 3. **灵活的通知模型**:Spring AOP提供了多种类型的通知,...

    spring aop 自定义注解保存操作日志到mysql数据库 源码

    2、能够清楚的知道如何用spring aop实现自定义注解以及注解的逻辑实现 (需要知道原理的请看spring aop源码,此处不做赘述) 3、可在现有源码上快速进行功能扩展 4、spring boot,mybatis,druid,spring aop的使用

    Spring AOP实现机制

    **Spring AOP 实现机制详解** Spring AOP(面向切面编程)是Spring框架的核心特性之一,它允许程序员在不修改源代码的情况下,通过“切面”来插入额外的业务逻辑,如日志、事务管理等。AOP的引入极大地提高了代码的...

    基于注解实现SpringAop

    基于注解实现SpringAop基于注解实现SpringAop基于注解实现SpringAop

    spring aop的demo

    在`springAop1`这个压缩包中,可能包含了一个简单的应用示例,展示了如何定义一个切面类,以及如何在该类中定义通知方法。例如,我们可能会看到一个名为`LoggingAspect`的类,其中包含了`@Before`注解的方法,用于在...

    spring aop 五个依赖jar

    Spring AOP(面向切面编程)是Spring框架的重要组成部分,它提供了一种模块化和声明式的方式来处理系统中的交叉关注点,如日志、事务管理等。在Java应用中,AOP通过代理模式实现了切面编程,使得我们可以将业务逻辑...

    spring AOP依赖三个jar包

    Spring AOP,即Spring的面向切面编程模块,是Spring框架的重要组成部分,它允许开发者在不修改源代码的情况下,对程序进行横切关注点的处理,如日志、事务管理等。实现这一功能,主要依赖于三个核心的jar包:aop...

    spring AOP 引入jar包,spring IOC 引入Jar包

    Spring AOP 和 Spring IOC 是 Spring 框架的两个核心组件,它们对于任何基于 Java 的企业级应用开发都至关重要。Spring AOP(面向切面编程)允许开发者在不修改源代码的情况下,通过“切面”来插入新的行为或增强已...

    @AspectJ配置Spring AOP,demo

    `springAOP2`可能是一个包含具体示例代码的目录。`基于@AspectJ配置Spring AOP之一 - 飞扬部落编程仓库-专注编程,网站,专业技术.htm`和其关联的`_files`目录可能包含了一个详细的教程或演示如何配置和运行@AspectJ的...

    反射实现 AOP 动态代理模式(Spring AOP 的实现原理)

    面向切面编程(AOP)是一种编程范式,旨在将横切关注点(如日志、安全等)与业务逻辑分离,从而提高模块化。...利用Java反射机制和Spring AOP框架,开发者可以方便地实现AOP,从而提升代码的模块化和可维护性。

    spring-aop实例

    Spring AOP(面向切面编程)是Spring框架的重要组成部分,它提供了一种强大的方式来实现横切关注点,如日志、事务管理、安全性等,从而解耦应用程序的核心业务逻辑。在Spring AOP中,关注点被模块化为独立的“切面”...

    spring aop 学习笔记

    Spring AOP(面向切面编程)是Spring框架的重要组成部分,它提供了一种模块化和抽象化的方法来处理系统中的交叉关注点,如日志、事务管理、安全性等。本学习笔记将深入探讨Spring AOP的核心概念、工作原理以及实际...

Global site tag (gtag.js) - Google Analytics