Spring——案例-业务层接口执行效率和AOP通知获取数据+AOP总结

news2025/1/24 17:41:52

执行时间获取:记录开始时间和结束时间,取差值。

这里使用环绕通知来实现。

环境准备:

项目文件结构:

业务层接口和实现类:

 数据层:

采用mybatis注解开发,这里没有实现类,直接在接口方法里面实现映射。

domain层:

实现了数据库里面每一个属性的setter和getter方法以及一个tostring方法。

 jdbc.properties文件下

SpringConfig配置类里面加载了 properties文件和jdbc以及mybatis的配置

Jdbc配置文件下:

使用一个Druid作为数据源 

 Mybayis配置文件下

 加载了两个bean一个是SqlSessionFactory的bean,还有一个映射扫描的bean。

 测试代码:

在test目录下整合了一个JUnit的测试类,并有两个查询的方法测试

 AOP层:

现在SpringConfig配置类上添加一个发现Aspet的注解

 再创建一个通知类,在里面定义一个切入点包含了业务层的所有操作,然后使用环绕通知的方式测试业务层接口执行万次的效率。 

 正常输出

 现在的运行方法无法得知测试的是哪一个接口的哪一个实现类,为此需要获取是哪一个连接点的信息,用到了上面环绕方法中的属性参数 ProceedingJoinPoint,这个就是执行的连接点。

现在使用一个它下面的一个方法getSignature(),获取一次执行的签名信息,里面封装了一次执行的过程。Signature下的get方法就可以获取到很多信息

输出得到了一次执行里面的类型和方法名

 

 AOP通知获取数据

  • 获取原始操作的参数
  • 获取原始操作的返回值
  • 获取原始操作的异常

环境准备二: 

Dao层的借口实现类,模拟根据id查询姓名

 测试代码里面:

在前置通知里面获取参数

使用一个JoinPoint,用它下面的getArgs方法获取原始方法的参数

    @Before("pt()")
    public void before(JoinPoint jp){
        Object[] args= jp.getArgs();
        System.out.println(Arrays.toString(args));
        System.out.println("before advice...");
    }

输出为一个参数构成的数组,有多个参数就有多个不同类型的数据

 在后置通知里面获取参数

和在前置通知获取参数一模一样

    @After("pt()")
    public void after(JoinPoint jp){
        Object[] args= jp.getArgs();
        System.out.println(Arrays.toString(args));
        System.out.println("after advice...");
    }

在环绕通知里面获取参数和返回值和异常

和上面类似,只是从JoinPoint改成了ProceedingJoinPoint,另外,这里面的args可以修改。但是数量和类型必须对应相同,这就是数据劫持?        

    @Around("pt()")
    public Object around(ProceedingJoinPoint pjp) throws Throwable {
        Object[] args=pjp.getArgs();
        System.out.println(Arrays.toString(args));
        args[0]=150;
       Object ret= pjp.proceed(args);
        return ret;
    }

输出如图,原本在环绕通知里面刚获取到时是100,经过修改返回了一个150.

异常获取

使用catch环绕,其中的Throwable属性的参数就是异常

 @Around("pt()")
    public Object around(ProceedingJoinPoint pjp)  {
        Object[] args=pjp.getArgs();
        System.out.println(Arrays.toString(args));
        args[0]=150;
        Object ret= null;
        try {
            ret = pjp.proceed(args);
        } catch (Throwable e) {
            throw new RuntimeException(e);
        }
        return ret;
    }

在返回后通知里面获取返回值

解释为如果过原始方法又返回值,就把它装到原始变量叫ret的形参当中

    @AfterReturning(value="pt()",returning = "ret")
    public void afterReturning(Object ret){
        System.out.println("afterReturning advice..."+ret);
    }

正常输出

如果参数列存在两个参数,必须是JoinPoint在前面

    @AfterReturning(value="pt()",returning = "ret")
    public void afterReturning(JoinPoint jp,Object ret){
        System.out.println("afterReturning advice..."+ret);
    }

异常后通知获取异常

和上面返回后通知获取返回值类型

    @AfterThrowing(value="pt()",throwing = "t")
    public void afterThrowing(Throwable t){
        System.out.println("afterThrowing advice..."+t);
    }

在原始方法中出现一个异常

@Repository
public class BookDaoImpl implements BookDao {
    public String findName(int id){
        System.out.println("id:"+id);

        if(true) throw new NullPointerException();

        return "itcast";
    }
}

输出如下

AOP总结

 

 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/403915.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Altium designer--软件简介及安装教程(Altium designer16)

一、软件介绍(完整安装包资源见文末链接,含破解license) Altium Designer 是一款简单易用、原生3D设计增强的一体化设计环境,结合了原理图、ECAD库、规则和限制条件、BoM、供应链管理、ECO流程和世界一流的PCB设计工具。通过原理…

Baumer工业相机中曝光与增益两种功能的优点和作用以及使用方法

项目场景 Baumer工业相机堡盟相机是一种高性能、高质量的工业相机,可用于各种应用场景,如物体检测、计数和识别、运动分析和图像处理。 Baumer的万兆网相机拥有出色的图像处理性能,可以实时传输高分辨率图像。此外,该相机还具有…

[NOIP2009 提高组] 最优贸易(C++,tarjan,topo,DP)

题目描述 $C 国有国有国有 n 个大城市和个大城市和个大城市和 m$ 条道路,每条道路连接这 nnn个城市中的某两个城市。任意两个城市之间最多只有一条道路直接相连。这 mmm 条道路中有一部分为单向通行的道路,一部分为双向通行的道路,双向通行的…

OpenHarmony通过MQTT连接 “改版后的华为IoT平台”

一、前言 本篇文章我们使用的是BearPi-HM_Nano开发板:小熊派的主板+E53_IA1扩展板 源码用的是D6_iot_cloud_oc,点击下载BearPi-HM_Nano全量源码 那么为什么要写这篇呢? 前段时间看到OpenHarmony群里,经常有小伙伴问接入华为IoT平台的问题,他们无法正常连接到华为IoT平台等…

【数据结构】二叉树相关OJ题

文章目录一、单值二叉树二、检查两颗树是否相同三、判断一棵树是否为另一颗树的子树四、对称二叉树五、二叉树的前序遍历六、二叉树中序遍历七、二叉树的后序遍历八、二叉树的构建及遍历一、单值二叉树 单值二叉树 题目描述 如果二叉树每个节点都具有相同的值,那…

【互联网架构】聊一聊所谓的“跨语言、跨平台“

文章目录序跨语言跨平台【饭后杂谈】为什么有人说Java的跨平台很鸡肋?序 很多技术都具有跨语言、跨平台的特点 比如JSON是跨语言的、Java是跨平台的、UniAPP、Electron是跨平台的 跨语言和跨平台,是比较重要的一个特性。这些特性经常能够决定开发者是否…

软件测试项目实战,一比一还原可以写进简历的

项目一:ShopNC商城 项目概况: ShopNC商城是一个电子商务B2C电商平台系统,功能强大,安全便捷。适合企业及个人快速构建个性化网上商城。 包含PCIOS客户端Adroid客户端微商城,系统PC后台是基于ThinkPHP MVC构架开发的跨…

ubuntu-22.04.2网络配置和root登录和root远程ssh登录

配置网络: 1.查看网卡名称 ip addr(ifconfig 无法使用,需要后期安装) 2. 配置静态IP (1)进入网络配置文件: vim /etc/netplan/00-installer-config.yaml (2)按一下 i ,进入插入模式&#…

网络 | 数据链路层讲解 | MAC帧与APR协议

最大以太网帧大小指的是以太网帧从目的地址到冗余校验的总字节数。在802.3标准里,规定了一个以太网帧的数据部分(Payload)的最大长度是1500个字节,这个数也是MTU。在这个限制之下,最长的以太网帧包括6字节的目的地址(DMAC)、6字节的源地址(SM…

【C++】list的模拟实现

文章目录1.list 底层2. list的模拟实现1. list_node 类设计2. list类如何调用类型3 .push_back(正常实现)4. 迭代器的实现第一个模板参数Tconst迭代器第二个模板参数Ref第三个模板参数Ptr对list封装的理解5. insert6.push_back与 push_front(复用)7. erase8. pop_back与pop_fro…

[c++]list模拟实现

目录 前言: 学习类的方式: 1 类成员变量 1.1 list成员变量 1.2 结点结构体变量 1.3 迭代器成员变量 2 默认函数——构造 2.1 结点结构体构造函数 2.2 list构造函数 2.3 迭代器构造函数 3 迭代器实现 3.1 list部分 3.2 迭代器结构体部分 3.2…

Spring MVC程序开发(三大功能)

文章目录一、什么是Spring MVC?1.MVC定义2.MVC与Spring MVC的关系3.创建方式二、Spring MVC的核心功能1.连接功能浏览器获取前端接口和后端程序连接功能实现get和post的区别Spring Boot热部署2.获取参数(1)传递单个参数(2)传递对…

信捷 XDH Ethercat A_MOVER指令

本指令以相对位置运动 如果当前位置在p点,执行本A_MOVER指令结束后,相对p点前移或后退一段距离,这个距离需要在指令里指定。每次执行A_MOVER都是执行前的当前位置为参考点,只要目标位置不为0,都会运动。上图中&#xf…

MyBatis-1:基础概念+环境配置

什么是MyBatis?MyBatis是一款优秀的持久层框架,支持自定义sql,存储过程以及高级映射。MyBatis就是可以让我们更加简单的实现程序和数据库之间进行交互的一个工具。可以让我们更加简单的操作和读取数据库的内容。MyBatis的官网:htt…

弱监督实例分割 Box-supervised Instance Segmentation with Level Set Evolution 论文笔记

弱监督实例分割 Box-supervised Instance Segmentation with Level Set Evolution 论文笔记一、Abstract二、引言三、相关工作3.1 基于 Box 的实例分割3.2 基于层级的分割四、提出的方法4.1 图像分割中的层级模型4.2 基于 Box 的实例分割在 Bounding Box 内的层级进化输入的数据…

elasticsearch 分布式搜索引擎3

1.数据聚合 **聚合(aggregations)**可以让我们极其方便的实现对数据的统计、分析、运算。例如: 什么品牌的手机最受欢迎?这些手机的平均价格、最高价格、最低价格?这些手机每月的销售情况如何? 实现这些…

Altium Designer(AD)软件使用记录04-AD设计文件输出汇总

目录Altium Designer(AD)软件使用记录04-AD设计文件输出汇总准备工作1、放置层标识(标清每个层的顺序)2、放置钻孔图(表明孔的一些参数)3、设置原点坐标一、文件输出1、Gerber文件(光绘文件)2、钻孔文件3、…

EasyExcell导出excel添加水印

EasyExcell导出excel添加水印1、添加easyExcel相关依赖2、准备基础工具类3、创建水印handler类4、创建单元测试类WriteTest.class5、测试结果1、添加easyExcel相关依赖 <dependency><groupId>org.apache.poi</groupId><artifactId>poi</artifactId&…

Reactor模式

Reactor是一种设计模式&#xff0c;可以用于构建高并发的网络服务器。 Reactor模式的好处在于&#xff1a;可以在一个或多个reactor线程使用多路复用技术去管理所有网络连接连接建立、IO请求&#xff0c;保证工作线程不被IO阻塞。 前置知识&#xff1a;IO多路复用技术 1. 传统网…

如何通过外贸网站SEO优化,提升您的品牌曝光度和海外业务销售额?

随着全球化的不断推进和互联网的普及&#xff0c;越来越多的外贸企业开始重视SEO优化&#xff0c;以提升自身品牌的曝光度和海外业务的销售额。 但是&#xff0c;对于许多外贸企业而言&#xff0c;SEO优化似乎是一个非常陌生的领域&#xff0c;他们并不清楚该如何进行优化。 …