java aop 实例_Spring aop 简单示例

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

基于两种配置方式:

基于xml配置

基于注解配置

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

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

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

c51519dd05ad0406ccd60a59828e0500.png

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

第一种配置方式

基于xml方式配置

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

13f4529a8013c96fe090a092b5b872cd.png

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

接下来看下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中是如何配置的

c327c872a3e9b8b320d6a1592e2e6652.png

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的时候出的问题

深坑

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值