简单的记录一下spring aop的一个示例

基于两种配置方式:

基于xml配置

基于注解配置

这个例子是模拟对数据库的更改操作添加事物

其实并没有添加,只是简单的输出了一下记录

首先看下整个例子的目录图

全部代码就不贴了,数目有点多,不过很简单,看一部分就能够明白

第一种配置方式

基于xml方式配置

首先将service,dao注册到spring容器

配置一下扫描包还是很方便的

接下来看下service

1 packagecom.yangxin.core.service.impl;2

3 importorg.springframework.beans.factory.annotation.Autowired;4 importorg.springframework.stereotype.Service;5

6 importcom.yangxin.core.dao.UserDao;7 importcom.yangxin.core.pojo.User;8 importcom.yangxin.core.service.UserService;9

10 @Service11 public class UserServiceImpl implementsUserService {12

13 @Autowired14 privateUserDao userDao;15

16 @Override17 public voidaddUser(User user) {18 userDao.insertUser(user);19 System.out.println("添加成功");20 }21

22 @Override23 public voiddeleteUser(String name) {24 userDao.deteleUser(name);25 System.out.println("删除成功");26 }27

28 }

要做的事情很简单,插入一条数据,删除一条数据

接下来看下切面代码

1 packagecom.yangxin.core.transaction;2

3 importorg.aspectj.lang.ProceedingJoinPoint;4

5 importcom.yangxin.core.pojo.User;6

7 public classTransactionDemo {8

9 //前置通知

10 public voidstartTransaction(){11 System.out.println("begin transaction ");12 }13

14 //后置通知

15 public voidcommitTransaction(){16 System.out.println("commit transaction ");17 }18

19 //环绕通知

20 public void around(ProceedingJoinPoint joinPoint) throwsThrowable{21 System.out.println("begin transaction");22

23 joinPoint.proceed();24

25 System.out.println("commit transaction");26 }27

28 }

然后看下这个切面在applicationContext.xml中是如何配置的

1

2

3

4

5

6

7

8

9

10

11

这里没有演示环绕通知

好了,运行测试代码

测试代码如下

1   @Test2 public voidtest1(){3 ApplicationContext applicationContext = new ClassPathXmlApplicationContext("spring/applicationContext.xml");4

5 UserService userService = applicationContext.getBean(UserService.class);6

7 User user = newUser();8

9 user.setAge(19);10 user.setName("yangxin");11

12 userService.addUser(user);13 userService.deteleUser("yangxin");

1415

16 }

控制台输出如下

begin transaction

添加成功

commit transaction

begin transaction

删除成功

commit transaction

现在来测试一下环绕通知

修改一下applicationContext.xml中的配置切面那一部分

修改后的代码

1

2

3

4

5

6

7

8

9

运行测试代码

输出如下

begin transaction

添加成功

commit transaction

begin transaction

删除成功

commit transaction

好了,现在贴下如何用注解的方法

贴下基于注解的切面的代码

1 packagecom.yangxin.core.transaction;2

3 importorg.aspectj.lang.ProceedingJoinPoint;4 importorg.aspectj.lang.annotation.AfterReturning;5 importorg.aspectj.lang.annotation.Around;6 importorg.aspectj.lang.annotation.Aspect;7 importorg.aspectj.lang.annotation.Before;8 importorg.aspectj.lang.annotation.Pointcut;9

10 @Aspect11 public classTransactionDemo2 {12

13 @Pointcut(value="execution(* com.yangxin.core.service.*.*.*(..))")14 public voidpoint(){15

16 }17

18 @Before(value="point()")19 public voidbefore(){20 System.out.println("transaction begin");21 }22

23 @AfterReturning(value = "point()")24 public voidafter(){25 System.out.println("transaction commit");26 }27

28 @Around("point()")29 public void around(ProceedingJoinPoint joinPoint) throwsThrowable{30 System.out.println("transaction begin");31 joinPoint.proceed();32 System.out.println("transaction commit");33

34 }35 }

在applicationContext.xml中配置

1

1

测试步骤和以上一致,这里就不贴了

完毕

记一下使用javaConfig配置方式的一些坑

以上 切面 不管是基于注解的还是基于xml配置的   这里把切面加载到容器中都是用xml配置bean的方式

如果用javaConfig方式的话

需要在配置类上加上 @EnableAspectJAutoProxy 注解

然后如果使用扫包的方式配置切面bean的话

切面上除了要加上@Aspect注解标识为这是一个切面bean之外

还需要在上面加上@component这个注解

很急很关键

排错的时候只关注切点表达式的问题了

当时一直在找切点表达式的问题

其实这个表达式写的是没有问题的

是配置切面bean的时候出的问题

深坑

java aop 实例_Spring aop 简单示例相关推荐

  1. java dto 实例_Spring Boot DTO示例:实体到DTO的转换

    在本教程中,我们将学习如何在Spring Boot应用程序中创建DTO(数据传输对象)类,以及如何使用ModelMapper库将实体转换为DTO,反之亦然. 数据传输对象设计模式是一种经常使用的设计模 ...

  2. java读取ACCESS数据库的简单示例

    java读取ACCESS数据库的简单示例  虽然简单,对初学者来说,如果没有一段可以成功执行的代码供参考,还真难调试  先用ACCESS建一个数据库 DB1.MDB,里面有一表"table1 ...

  3. java播放声音类和一个简单示例

    java播放声音类和一个简单示例 播放声音的类 复制代码 代码如下:  import java.io.File; import java.io.IOException; import javax.so ...

  4. java调用百度地图api简单示例--获取国内任意两地之间距离

    老师让我们从百度地图的api上获取数据源最为两地运输距离,结果百度地图api的开发文档居然连个示例都没有...于是上网找了半天,都是一百多行的源码,我就想用个api,你给我这玩意???终于最后还是找到 ...

  5. java args例子_Spring AOP中使用args表达式的方法示例

    本文实例讲述了Spring AOP中使用args表达式的方法.分享给大家供大家参考,具体如下: 一 配置 xmlns:xsi="http://www.w3.org/2001/XMLSchem ...

  6. java after方法_spring AOP的After增强实现方法实例分析

    本文实例讲述了spring AOP的After增强实现方法.分享给大家供大家参考,具体如下: 一 配置 xmlns:xsi="http://www.w3.org/2001/XMLSchema ...

  7. java切点配置_Spring AOP中定义切点的实现方法示例

    本文实例讲述了Spring AOP中定义切点的实现方法.分享给大家供大家参考,具体如下: 一 配置 xmlns:xsi="http://www.w3.org/2001/XMLSchema-i ...

  8. java spring mvc 实例_spring mvc 简单实例

    转至:http://blog.csdn.net/dingx/article/details/2242105 Spring Framework可以被使用在很多场合之中,考虑到目前大多数Java EE的项 ...

  9. java 切面表达式_Spring AOP表达式(execution)规则

    如:execution(* com.sample.service.impl..*.*(..)) 解释如下: 符号 含义 execution() 表达式的主体: 第一个"*"符号 表 ...

最新文章

  1. 经典再读 | NASNet:神经架构搜索网络在图像分类中的表现
  2. python pandas DataFrame 查找NaN所在的位置
  3. ibatis调用sqlserver存储过程
  4. 常见开源协议!【科普】
  5. [Day9]面向对象
  6. php lock sh,php文件加锁 lock_sh ,lock_ex
  7. C++重载一些需要注意的地方
  8. 开源搜索服务 Apache Solr 出现多个高危漏洞
  9. UNITY自带的3D object没有三角形?
  10. linux 文件夹中过滤文件内容,【shell】对指定文件夹中文件进行过滤,并修改文件内容的shell脚本...
  11. 疯狂Java讲义笔记整理
  12. python numpy官网_如果通过官网下载Python-Numpy的文档
  13. Django修改app名称和数据表迁移方案
  14. 5分钟外设学堂:耳机不响别慌,换个插头能救活!
  15. 计算机辅助技术英语,电子计算机辅助技术(CAD)
  16. 房地产楼盘三维展示|户型3D展示效果
  17. 显卡,显卡驱动,nvcc, cuda driver,cudatoolkit,cudnn
  18. 数据库主键、外键和唯一键的区别
  19. 几何光学学习笔记(34)- 7.5 颜色的匹配
  20. React Tutorial (updating)

热门文章

  1. [APIO2018] New Home 新家(线段树,二分答案,离散化)
  2. 牛客题霸 [求平方根] C++题解/答案
  3. 牛客题霸 [字符串变形]C++题解/答案
  4. [ZJOI2011]营救皮卡丘(费用流 + 最短路)
  5. YBTOJ:矛盾指数(网络流-最大权闭合图)
  6. ssl2124-涂色【离散化】
  7. 数学基础知识(高精、快速幂、龟速乘……)
  8. 2021“MINIEYE杯”中国大学生算法设计超级联赛(4)Display Substring(后缀数组+二分)
  9. 练习利用LSTM实现手写数字分类任务
  10. SpringCloud Ribbon(一)之自定义负载均衡器ILoadBalancer