使用Spring的注解方式实现AOP

2023-05-16

Spring对AOP的实现提供了很好的支持。下面我们就使用Spring的注解来完成AOP做一个例子。

首先,为了使用Spring的AOP注解功能,必须导入如下几个包。aspectjrt.jar,aspectjweaver.jar,cglib-nodep.jar.

然后我们写一个接口

package com.bird.service;

public interface PersonServer {

	public void save(String name);
	public void update(String name, Integer id);
	public String getPersonName(Integer id);
	
}

和一个接口实现类

package com.bird.service.impl;

import com.bird.service.PersonServer;

public class PersonServiceBean implements PersonServer{
	
	@Override
	public void save(String name) {
		
		System.out.println("我是save方法");
	//	throw new RuntimeException();
	}

	@Override
	public void update(String name, Integer id) {
		
		System.out.println("我是update()方法");
	}

	@Override
	public String getPersonName(Integer id) {
		
		System.out.println("我是getPersonName()方法");
		return "xxx";
	}

}

下面使用Spring注解方式对这个Bean进行方法拦截

package com.bird.service;

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;

/**
 * 切面
 * @author Bird
 *
 */
@Aspect
public class MyInterceptor {
	@Pointcut("execution(* com.bird.service.impl.PersonServiceBean.*(..))")
	private void anyMethod(){}//定义一个切入点
	
	@Before("anyMethod() && args(name)")
	public void doAccessCheck(String name){
		System.out.println(name);
		System.out.println("前置通知");
	}
	
	@AfterReturning("anyMethod()")
	public void doAfter(){
		System.out.println("后置通知");
	}
	
	@After("anyMethod()")
	public void after(){
		System.out.println("最终通知");
	}
	
	@AfterThrowing("anyMethod()")
	public void doAfterThrow(){
		System.out.println("例外通知");
	}
	
	@Around("anyMethod()")
	public Object doBasicProfiling(ProceedingJoinPoint pjp) throws Throwable{
		System.out.println("进入环绕通知");
		Object object = pjp.proceed();//执行该方法
		System.out.println("退出方法");
		return object;
	}
}
@Pointcut("execution(* com.bird.service.impl.PersonServiceBean.*(..))")
这句话是方法切入点,execution为执行的意思,*代表任意返回值,然后是包名,.*意思是包下面的所有子包。(..)代

表各种方法.

然后下面的注解就比较简单了,就是在使用方法前和中,还有环绕拦截/

然后在Spring的配置文件中继续配置Bean,需要打开AOP命名空间

<?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
	   http://www.springframework.org/schema/aop 
	   http://www.springframework.org/schema/aop/spring-aop-2.5.xsd">
		
		<aop:aspectj-autoproxy/>
	<bean id="personServiceBean" class="com.bird.service.impl.PersonServiceBean"/>
    <bean id="myInterceptor" class="com.bird.service.MyInterceptor"/>
   
</beans>

然后建立一个Junit测试

package junit.test;

import org.junit.Test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;

import com.bird.service.PersonServer;

public class SpringAOPTest {
	
	@Test
	public void inteceptorTest(){
		ApplicationContext ctx = new ClassPathXmlApplicationContext("beanAop.xml");
		PersonServer bean = (PersonServer)ctx.getBean("personServiceBean");
		bean.save(null);
	}
	

}

测试结果为

2012-3-12 18:08:39 org.springframework.context.support.AbstractApplicationContext prepareRefresh
信息: Refreshing org.springframework.context.support.ClassPathXmlApplicationContext@dd20f6: display name [org.springframework.context.support.ClassPathXmlApplicationContext@dd20f6]; startup date [Mon Mar 12 18:08:39 CST 2012]; root of context hierarchy
2012-3-12 18:08:40 org.springframework.beans.factory.xml.XmlBeanDefinitionReader loadBeanDefinitions
信息: Loading XML bean definitions from class path resource [beanAop.xml]
2012-3-12 18:08:40 org.springframework.context.support.AbstractApplicationContext obtainFreshBeanFactory
信息: Bean factory for application context [org.springframework.context.support.ClassPathXmlApplicationContext@dd20f6]: org.springframework.beans.factory.support.DefaultListableBeanFactory@b0bad7
2012-3-12 18:08:40 org.springframework.beans.factory.support.DefaultListableBeanFactory preInstantiateSingletons
信息: Pre-instantiating singletons in org.springframework.beans.factory.support.DefaultListableBeanFactory@b0bad7: defining beans [org.springframework.aop.config.internalAutoProxyCreator,personServiceBean,myInterceptor]; root of factory hierarchy
null
前置通知
进入环绕通知
我是save方法
后置通知
退出方法
最终通知



本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

使用Spring的注解方式实现AOP 的相关文章

随机推荐

  • 第五章 控制系统的稳定性分析

    2006 04 04 10 26 46 第五章 控制系统的稳定性分析 控制系统实用的首要条件是系统必须稳定 本章介绍稳定性的基本概念 稳定性判据 系统的相对稳定性 1 控制系统稳定性的基本概念 一 xff0e 稳定性的定义 xff1a 系统
  • 【无人机开发】通讯协议MavLink详解

    1 MAVLink简介 MAVLink xff08 Micro Air Vehicle Link xff0c 微型空中飞行器链路通讯协议 xff09 是无人飞行器与地面站 xff08 Ground Control Station xff0c
  • Android注解基础用法

    注解的介绍 注解介绍 注解是在 Java SE5 引入进来的 注解又称为标注 xff0c 用于为代码提供元数据 作为元数据 xff0c 注解不直接影响你的代码执行 xff0c 但也有一些类型的注解实际上可以用于这一目的 可以作用在类 方法
  • EXCEL数据导入TIPTOP ERP 系统

    测试系统TIPTOP GP 3 0 主要用到DDE API 函数描述DDEConnectThis function opens a DDE connectionDDEExecuteThis function executes a comma
  • 【Python】闭包的实现原理,如何在内部函数修改外部函数的变量

    什么是闭包 xff1f 闭包是指在一个函数中定义了一个另外一个函数 xff0c 内函数里运用了外函数的临时变量 xff0c 并且外函数的返回值是内函数的引用 xff0c 这样就构成了一个闭包 闭包的使用 xff0c 可以隐藏内部函数的工作细
  • C++ 构造函数后加冒号

    其实冒号后的内容是初始化成员列表 xff0c 一般有三种情况 xff1a 1 对含有对象成员的对象进行初始化 xff0c 例如 xff0c 类line有两个私有对象成员startpoint endpoint line的构造函数写成 xff1
  • PCL-- cpprestsdk发送http请求

    前言 通过前文的内容 xff0c 以及将基本的PCL的库函数学习完成 xff0c 但是考虑到系统的存在 xff0c 并非孤立的 xff0c 是相互沟通交流的 考虑到当下可移植性 xff0c 以及便捷性 xff0c 采用Http的方式进行 x
  • PX4 offboard模式能接收的mavros指令

    以下内容针对px4 v1 11 3 xff08 2021 01 xff09 px4 offboard模式下可以接收上位机发送来的setpoint值 xff0c 可以利用ROS包mavros来发送这些setpoint xff08 期望值 xf
  • NVIDIA Jetson NX 控制GPIO

    目录 前言运行引脚图片 前言 看到一些博客说需要pip安装Jetson GPIO 以及通过下面命令设置用户权限 sudo groupadd span class token operator span f span class token
  • 程序员们,AI来了,机会来了,危机也来了

    程序员们 xff0c AI来了 xff0c 机会来了 xff0c 危机也来了 1 人工智能真的来了 纵观古今 xff0c 很少有计算机技术能有较长的发展寿命 xff0c 大部分昙花一现 xff0c 比如 xff1a 昔日的DOS windo
  • VNC连接服务器(centos 7)后黑屏,鼠标是一个小方框?

    问题描述 xff1a VNC连接服务器 xff08 centos 7 xff09 后黑屏 xff0c 鼠标是一个小方框 xff1f 尝试了网上说的思路 xff0c 大部分不能解决问题 只有一个部分解决 xff08 可以出来类似打开主文件夹后
  • Docker 命令

    1 Docker命令 docker info 显示 Docker 系统信息 xff0c 包括镜像和容器数 docker version 显示 Docker 版本信息 2 镜像命令 docker images 列出本地镜像 docker im
  • 四轴无人机——MAVLink通讯协议

    MAVLink 是一种非常轻量级的消息传递协议 xff0c 用于与无人机 xff08 以及机载无人机组件之间 xff09 进行通信 MAVLink 遵循现代混合发布 订阅和点对点设计模式 xff1a 数据流作为主题发送 发布 xff0c 而
  • 【Java】 java | java连接mysql报错 | Unsupported record version Unknown-0.0

    一 错误信息 Unsupported record version Unknown 0 0 二 问题 jdbc的ssl连接问题 三 解决 jdbc mysql 192 168 100 122 3306 torna useUnicode 61
  • 【Linux】 linux | rpm | rpm安装 | 卸载 | 升级 | 查询已安装

    rpm资源搜索 https rpmfind net linux RPM http rpm pbone net rpm安装 rpm ivh rpm卸载 rpm e rpm查询已安装 rpm qa grep rpm升级库 rpm Uvh
  • 【Docker】docker | 迁移docker目录

    一 场景说明 1 物理机磁盘空间不够用了 2 docker的镜像 容器 卷等资料的默认路径为 xff1a var lib docker 3 增加了数据盘挂在 xff0c 需要将docker的全部资料更换个目录 二 操作 确认是否满足切换条件
  • 【Docker】docker | 更新源

    一 编辑 vi etc docker daemon json 二 更新源并保存 34 registry mirrors 34 34 https xxxxx mirror aliyuncs com 34 34 http mirrors ust
  • 【Redis】redis | redis操作 | 指令 | set

    一 说明 1 记录redis常用操作 2 基于redis cli 3 基于redis数据结构 二 Set xff08 集合 xff09 赋值 sadd tcp online iccid 001 遍历 smembers tcp online
  • Ros-gazebo xacro文件命名空间

    xacro是urdf模型文件的升级版 如果想要在gazebo中用ros的spawn model以 lt group ns 61 34 arg namespace 34 gt 同时打开多个这个xacro模型 xff0c 要注意xacro文件中
  • 使用Spring的注解方式实现AOP

    Spring对AOP的实现提供了很好的支持 下面我们就使用Spring的注解来完成AOP做一个例子 首先 xff0c 为了使用Spring的AOP注解功能 xff0c 必须导入如下几个包 aspectjrt jar aspectjweave