Spring AOP应用实例demo

简介:

AOPAspect-Oriented Programming。面向方面编程)。能够说是OOPObject-OrientedPrograming。面向对象编程)的补充和完好。OOP引入封装、继承和多态性等概念来建立一种对象层次结构,用以模拟公共行为的一个集合。


OOP的问题,AOP的补充


当我们须要为分散的对象引入公共行为的时候,OOP则显得无能为力。也就是说,OOP同意你定义从上到下的关系,但并不适合定义从左到右的关系。

比如日志功能。日志代码往往水平地散布在全部对象层次中,而与它所散布到的对象的核心功能毫无关系。对于其它类型的代码,如安全性、异常处理和透明的持续性也是如此。这样的散布在各处的无关的代码被称为横切(cross-cutting)代码。在OOP设计中,它导致了大量代码的反复,而不利于各个模块的重用。

 

所谓“方面”,简单地说,就是将那些与业务无关。却为业务模块所共同调用的逻辑或责任封装起来。便于降低系统的反复代码,降低模块间的耦合度,并有利于未来的可操作性和可维护性。

 

Spring中对 AOP的支持

 

Spring AOP代理由Spring IoC容器负责生成、管理,其依赖关系也由 IoC容器负责管理。因此,AOP代理能够直接使用容器中的其它Bean实例作为目标,这样的关系可由 IoC容器的依赖注入提供。Spring默认使用 Java动态代理来创建AOP代理。这样就能够为不论什么接口实例创建代理了。当须要代理的类不是代理接口的时候, Spring自己主动会切换为使用 CGLIB代理,也可强制使用 CGLIB


程序猿參与部分 


AOP编程事实上是非常easy的事情。

纵观 AOP编程,当中须要程序猿參与的仅仅有三个部分:

 

   定义普通业务组件。

   定义切入点,一个切入点可能横切多个业务组件。

   定义增强处理,增强处理就是在AOP框架为普通业务组件织入的处理动作。

 

所以进行 AOP编程的关键就是定义切入点和定义增强处理。一旦定义了合适的切入点和增强处理,AOP框架将会自己主动生成AOP代理。即:代理对象的方法 =增强处理 +被代理对象的方法。

 

Spring中使用方式:

 

基于 Annotation的“零配置”方式。

 

1)启动注解。配置文件applicationContext.xml

<!-- 启动对@AspectJ注解的支持 -->     
<aop:aspectj-autoproxy/>

<bean id="user" class="com.tgb.spring.aop.IUserImpl"/>

<bean id="check" class="com.tgb.spring.aop.CheckUser"/>

2)编写切面类

package com.tgb.spring.aop;

import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.After;
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 CheckUser {

	@Pointcut("execution(* com.tgb.spring.aop.*.find*(..))")
	public void checkUser(){
		System.out.println("**************The System is Searching Information For You****************");
	}
	
	@Pointcut("execution(* com.tgb.spring.aop.*.add*(..))")
	public void checkAdd(){
		System.out.println("**************<< Add User >> Checking.....***************");
	}
	
	@Before("checkUser()")
	public void beforeCheck(){
		System.out.println(">>>>>>>> 准备搜查用户..........");
	}
	
	@After("checkUser()")
	public void afterCheck(){
		System.out.println(">>>>>>>> 搜查用户完成..........");
	}

	@Before("checkAdd()")
	public void beforeAdd(){
		System.out.println(">>>>>>>> 添加用户--检查ing..........");
	}
	
	@After("checkAdd()")
	public void afterAdd(){
		System.out.println(">>>>>>>> 添加用户--检查完成!

未发现异常!.........."); } //声明围绕通知 @Around("checkUser()") public Object doAround(ProceedingJoinPoint pjp) throws Throwable { System.out.println("进入方法---围绕通知"); Object o = pjp.proceed(); System.out.println("退出方法---围绕通知"); return o; } }

3)定义接口

package com.tgb.spring.aop;

public interface IUser {

	public String findUser(String username);
	public void addUser(String username);
	public void findAll();
}

4)定义实现

package com.tgb.spring.aop;

import java.util.HashMap;
import java.util.Map;

public class IUserImpl implements IUser {

	public static Map map = null;
	public static void init(){
		String[] list = {"Lucy", "Tom", "小明", "Smith", "Hello"};
		Map tmp = new HashMap();
		for(int i=0; i<list.length; i++){
			tmp.put(list[i], list[i]+"00");
		}
		map = tmp;
	}
	public void addUser(String username) {
		init();
		map.put(username, username+"11");
		System.out.println("--------------【addUser】: "+username+" --------------");
		System.out.println("【The new List:"+map+"】");
	}

	public void findAll() {
		init();
		System.out.println("---------------【findAll】: "+map+" ------------------");
	}

	public String findUser(String username) {
		init();
		String password = "没查到该用户";
		if(map.containsKey(username)){
			password = map.get(username).toString();
		}
		System.out.println("-----------------【findUser】-----------------");
		System.out.println("-----------------Username:"+username+"-----------------");
		System.out.println("-----------------【Result】:"+password+"------------------");
		return password;
		
	}

}

5)測试

public class Test {
	
	public static void main(String as[]){
		BeanFactory factory = new ClassPathXmlApplicationContext("applicationContext.xml");
		IUser user = (IUser) factory.getBean("user");
		user.findAll();
		
		User u = new User();
//		u.setUsername("Tom");
//		user.findUser(u.getUsername());
		
		/*u.setUsername("haha");
		user.addUser(u.getUsername());*/
	}
}

运行结果:

 

进入方法---围绕通知

>>>>>>>>准备搜查用户..........

---------------【findAll】: {Smith=Smith00, Tom=Tom00, 小明=小明00, Lucy=Lucy00,Hello=Hello00} ------------------

退出方法---围绕通知

>>>>>>>> 搜查用户完成..........

 

注:@Before是在所拦截方法运行之前运行一段逻辑。@After是在所拦截方法运行之后运行一段逻辑。@Around是能够同一时候在所拦截方法的前后运行一段逻辑。

 

以上是针对注解的方式来实现。那么配置文件也一样,仅仅须要在applicationContext.xml中加入例如以下代码:

<!--  <aop:config>
		<aop:pointcut id="find" expression="execution(* com.tgb.spring.aop.*.find*(..))" />
		<aop:pointcut id="add" 	expression="execution(* com.tgb.spring.aop.*.add*(..))" />
		
		<aop:aspect id="checkUser" ref="check">
			<aop:before method="beforeCheck" pointcut-ref="find"/>
			<aop:after method="afterCheck" pointcut-ref="find"/>
		</aop:aspect>
		
		<aop:aspect id="checkAdd" ref="check">
			<aop:before method="beforeAdd" pointcut-ref="add"/>
			<aop:after method="afterAdd" pointcut-ref="add"/>
		</aop:aspect>
	
	</aop:config>-->

总结:

 

以上是简介了一下怎样使用Spring AOP,在使用的过程中也加深我们对AOP思想的理解。事实上AOP就是要我们实现热插拔效果,下篇会继续介绍Spring AOP的实现原理。

 

附:在使用过程中注意JDK版本号与易用的aspectJrt的版本号问题








本文转自mfrbuaa博客园博客,原文链接:http://www.cnblogs.com/mfrbuaa/p/5246595.html,如需转载请自行联系原作者
相关文章
|
4月前
|
监控 安全 Java
Spring AOP实现原理
本内容主要介绍了Spring AOP的核心概念、实现机制及代理生成流程。涵盖切面(Aspect)、连接点(Join Point)、通知(Advice)、切点(Pointcut)等关键概念,解析了JDK动态代理与CGLIB代理的原理及对比,并深入探讨了通知执行链路和责任链模式的应用。同时,详细分析了AspectJ注解驱动的AOP解析过程,包括切面识别、切点表达式匹配及通知适配为Advice的机制,帮助理解Spring AOP的工作原理与实现细节。
|
24天前
|
人工智能 监控 安全
如何快速上手【Spring AOP】?核心应用实战(上篇)
哈喽大家好吖~欢迎来到Spring AOP系列教程的上篇 - 应用篇。在本篇,我们将专注于Spring AOP的实际应用,通过具体的代码示例和场景分析,帮助大家掌握AOP的使用方法和技巧。而在后续的下篇中,我们将深入探讨Spring AOP的实现原理和底层机制。 AOP(Aspect-Oriented Programming,面向切面编程)是Spring框架中的核心特性之一,它能够帮助我们解决横切关注点(如日志记录、性能统计、安全控制、事务管理等)的问题,提高代码的模块化程度和复用性。
|
23天前
|
设计模式 Java 开发者
如何快速上手【Spring AOP】?从动态代理到源码剖析(下篇)
Spring AOP的实现本质上依赖于代理模式这一经典设计模式。代理模式通过引入代理对象作为目标对象的中间层,实现了对目标对象访问的控制与增强,其核心价值在于解耦核心业务逻辑与横切关注点。在框架设计中,这种模式广泛用于实现功能扩展(如远程调用、延迟加载)、行为拦截(如权限校验、异常处理)等场景,为系统提供了更高的灵活性和可维护性。
|
7月前
|
XML Java 测试技术
Spring AOP—通知类型 和 切入点表达式 万字详解(通俗易懂)
Spring 第五节 AOP——切入点表达式 万字详解!
342 25
|
6月前
|
Java 微服务 Spring
微服务——SpringBoot使用归纳——Spring Boot中使用拦截器——拦截器使用实例
本文主要讲解了Spring Boot中拦截器的使用实例,包括判断用户是否登录和取消特定拦截操作两大场景。通过token验证实现登录状态检查,未登录则拦截请求;定义自定义注解@UnInterception实现灵活取消拦截功能。最后总结了拦截器的创建、配置及对静态资源的影响,并提供两种配置方式供选择,帮助读者掌握拦截器的实际应用。
201 0
|
6月前
|
Java API 微服务
微服务——SpringBoot使用归纳——Spring Boot中的切面AOP处理——Spring Boot 中的 AOP 处理
本文详细讲解了Spring Boot中的AOP(面向切面编程)处理方法。首先介绍如何引入AOP依赖,通过添加`spring-boot-starter-aop`实现。接着阐述了如何定义和实现AOP切面,包括常用注解如`@Aspect`、`@Pointcut`、`@Before`、`@After`、`@AfterReturning`和`@AfterThrowing`的使用场景与示例代码。通过这些注解,可以分别在方法执行前、后、返回时或抛出异常时插入自定义逻辑,从而实现功能增强或日志记录等操作。最后总结了AOP在实际项目中的重要作用,并提供了课程源码下载链接供进一步学习。
669 0
|
6月前
|
Java 开发者 微服务
微服务——SpringBoot使用归纳——Spring Boot中的切面AOP处理——什么是AOP
本文介绍了Spring Boot中的切面AOP处理。AOP(Aspect Oriented Programming)即面向切面编程,其核心思想是分离关注点。通过AOP,程序可以将与业务逻辑无关的代码(如日志记录、事务管理等)从主要逻辑中抽离,交由专门的“仆人”处理,从而让开发者专注于核心任务。这种机制实现了模块间的灵活组合,使程序结构更加可配置、可扩展。文中以生活化比喻生动阐释了AOP的工作原理及其优势。
282 0
|
安全 Java Spring
Spring之Aop的底层原理
Spring之Aop的底层原理
|
设计模式 Java uml
Spring AOP 原理
Spring AOP 原理
87 0
Spring5入门到实战------9、AOP基本概念、底层原理、JDK动态代理实现
这篇文章是Spring5框架的实战教程,深入讲解了AOP的基本概念、如何利用动态代理实现AOP,特别是通过JDK动态代理机制在不修改源代码的情况下为业务逻辑添加新功能,降低代码耦合度,并通过具体代码示例演示了JDK动态代理的实现过程。
Spring5入门到实战------9、AOP基本概念、底层原理、JDK动态代理实现