`

spring aop

阅读更多

本文没有去探寻源码,只是根据现象去推理一下:

1 定义切面类:

package main.daoImpl;

import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.After;
import org.aspectj.lang.annotation.AfterReturning;
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.aspectj.lang.annotation.Pointcut;

@Aspect
public class LogAnnotationAspect {
	
	@Pointcut("execution(* main.daoImpl.*.*(..))")
	public void allMethod() {}

	@Before("allMethod()")
	public void before(JoinPoint jp) {
		System.out.println("Args:" + jp.getArgs());
		System.out.println("Kind:" + jp.getKind());
		System.out.println("Signature:" + jp.getSignature());
		System.out.println("Target:" + jp.getTarget());
		System.out.println("this:" + jp.getThis());
		System.out.println("正在进行权限校验!before...");
		System.out.println(jp.getSignature().getName());
		if (jp.getSignature().getName().equals("login")) {
		}
	}
	
	@After("allMethod()")
	public void after() {
		System.out.println("结束调用!after...");
	}
	
	@Around("allMethod()")
	public void around(ProceedingJoinPoint pjp) throws Throwable {
		System.out.println("环绕! around...");
		pjp.proceed();
	}
	
	@AfterReturning(pointcut="allMethod()", returning="rvt")
	public void afterReturning(Object rvt) {
		System.out.println("rrrrrrrrrrrrrrrrrrrrrrrr     " + rvt + "    rrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrr");
	}
	
	@AfterThrowing("allMethod()")
	public void afterThrow() {
		System.out.println("after throwing...");
	}
	
}

 2 目标类

   (1)目标类不实现接口:

     

package main.daoImpl;

import main.dao.TestDao;

public class TestDaoImpl {

	public String test() throws Exception {
		System.out.println("test main...");
		return "test data!";
	}
	

   测试代码:

  

	@Test
	public void test() {
		try {
			TestDaoImpl testDaoImpl = (TestDaoImpl)context.getBean("testDaoImpl");
			System.out.println("current class: " + testDaoImpl.getClass().getName());
			System.out.println("parent class or interface : " + testDaoImpl.getClass().getSuperclass().getName());
			System.out.println("is aop proxy: " + AopUtils.isAopProxy(testDaoImpl));
			System.out.println("is cglib proxy: " + AopUtils.isCglibProxy(testDaoImpl));
			System.out.println("is jdk proxy: " + AopUtils.isJdkDynamicProxy(testDaoImpl));
		} catch (Exception e) {
			e.printStackTrace();
		} finally {
			
		}
	}

    测试结果:

   current class: main.daoImpl.TestDaoImpl$$EnhancerByCGLIB$$a6cb1969
   parent class or interface : main.daoImpl.TestDaoImpl
  is aop proxy: true
  is cglib proxy: true
  is jdk proxy: false

  从获取的testDaoImpl的class名称为:main.daoImpl.TestDaoImpl$$EnhancerByCGLIB$$a6cb1969,熟悉cglib动态代理的应该知道,这类名称符合cglib动态代理生成类的命名,而且testDaoImpl父类的名称为:main.daoImpl.TestDaoImpl,也就是testDaoImpl继承了类main.daoImpl.TestDaoImpl,此恰恰符合cglib动态代理的特征;所以当目标类没有实现接口时,spring aop使用cglib动态代理生成一个代理类,把切面类

中配置的通知织入到动态代理类内,代理类调用方法时,就会触发通知。

 

    (2)目标类实现接口:

package main.daoImpl;

import main.dao.TestDao;

public class TestDaoImpl implements TestDao {

	public String test() throws Exception {
		System.out.println("test main...");
		return "test data!";
	}
	
}

    切面类和上面一致,测试代码为:

	@Test
	public void test() {
		try {
			TestDao testDaoImpl = (TestDao)context.getBean("testDaoImpl");
			System.out.println("current class: " + testDaoImpl.getClass().getName());
			System.out.println("parent class or interface : " + testDaoImpl.getClass().getSuperclass().getName());
			System.out.println("is aop proxy: " + AopUtils.isAopProxy(testDaoImpl));
			System.out.println("is cglib proxy: " + AopUtils.isCglibProxy(testDaoImpl));
			System.out.println("is jdk proxy: " + AopUtils.isJdkDynamicProxy(testDaoImpl));
		} catch (Exception e) {
			e.printStackTrace();
		} finally {
			
		}
	}

 测试结果:

current class: $Proxy13
parent class or interface : java.lang.reflect.Proxy
is aop proxy: true
is cglib proxy: false
is jdk proxy: true

testDaoImpl类名为$Proxy13, 继承了 java.lang.reflect.Proxy,由此可知当目标类实现接口的时候,spring aop 使用jdk的动态代理生成动态代理类把通知织入到动态代理类内

 

从上面的代码可知,spring aop的总体逻辑为,根据目标类是否实现接口来选择使用jdk还是使用cglib来生成代理类,把通知中的逻辑织入到代理类中

 

分享到:
评论

相关推荐

    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 自定义注解保存操作日志到mysql数据库 源码

    3、对spring aop认识模糊的,不清楚如何实现Java 自定义注解的 4、想看spring aop 注解实现记录系统日志并入库等 二、能学到什么 1、收获可用源码 2、能够清楚的知道如何用spring aop实现自定义注解以及注解的逻辑...

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

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

    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 IOC 引入Jar包

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

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

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

    Spring AOP实现机制

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

    springAOP配置动态代理实现

    Spring AOP(面向切面编程)是Spring框架的重要组成部分,它允许程序员在不修改源代码的情况下,通过在运行时插入额外的行为(如日志记录、性能监控等)来增强对象的功能。动态代理则是Spring AOP实现的核心技术之一...

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

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

    小马哥讲 Spring AOP 编程思想 - API 线索图.pdf

    在讨论Spring AOP(面向切面编程)时,首先需要理解几个核心概念。Spring AOP 是Spring框架提供的一个功能模块,它允许开发者将横切关注点(cross-cutting concerns)从业务逻辑中解耦出来,通过在方法调用前后进行...

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

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

    spring aop 五个依赖jar

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

    Spring AOP 入门作者:廖雪峰

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

    Spring源码最难问题:当Spring AOP遇上循环依赖.docx

    Spring源码最难问题:当Spring AOP遇上循环依赖 Spring源码中最难的问题之一是循环依赖问题,当Spring AOP遇上循环依赖时,该如何解决? Spring通过三级缓存机制解决循环依赖的问题。 在Spring中,bean的实例化...

    spring AOP依赖三个jar包

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

    spring aop的demo

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

    基于注解实现SpringAop

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

Global site tag (gtag.js) - Google Analytics