Spring4学习笔记-AOP(基于配置文件的方式)
引入的jar包与基于注解的方式引入的jar包相同
ArithmeticCalculator接口
1
2
3
4
5
6
7
8
9
10
11
|
package com.spring.aop.impl.xml; public interface ArithmeticCalculator { public int add( int i, int j); public int sub( int i, int j); public int mul( int i, int j); public int div( int i, int j); } |
接口实现类 ArithmeticCalculatorImpl.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
|
package com.spring.aop.impl.xml; public class ArithmeticCalculatorImpl implements ArithmeticCalculator{ @Override public int add( int i, int j) { int result = i + j; return result; } @Override public int sub( int i, int j) { int result = i - j; return result; } @Override public int mul( int i, int j) { int result = i * j; return result; } @Override public int div( int i, int j) { int result = i / j; return result; } } |
切面类 LoggingAspect.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
|
package com.spring.aop.impl.xml; import java.util.Arrays; import java.util.List; import org.aspectj.lang.JoinPoint; import org.aspectj.lang.ProceedingJoinPoint; public class LoggingAspect { public void beforeMethod(JoinPoint joinpoint) { String methodName = joinpoint.getSignature().getName(); List<Object>args = Arrays.asList(joinpoint.getArgs()); System.out.println( "前置通知:The method " + methodName + " begins with " + args); } public void afterMethod(JoinPoint joinpoint) { String methodName = joinpoint.getSignature().getName(); //List<Object>args = Arrays.asList(joinpoint.getArgs()); 后置通知方法中可以获取到参数 System.out.println( "后置通知:The method " + methodName + " ends " ); } public void afterReturnning(JoinPoint joinpoint, Object result) { String methodName = joinpoint.getSignature().getName(); System.out.println( "返回通知:The method " + methodName + " ends with " + result); } public void afterThrowing(JoinPoint joinpoint, Exception e) { String methodName = joinpoint.getSignature().getName(); System.out.println( "异常通知:The method " + methodName + " occurs exception " + e); } public Object aroundMethod(ProceedingJoinPoint point) { Object result = null ; String methodName = point.getSignature().getName(); try { //前置通知 System.out.println( "The method " + methodName + " begins with " + Arrays.asList(point.getArgs())); //执行目标方法 result = point.proceed(); //翻译通知 System.out.println( "The method " + methodName + " ends with " + result); } catch (Throwable e) { //异常通知 System.out.println( "The method " + methodName + " occurs exception " + e); throw new RuntimeException(e); } //后置通知 System.out.println( "The method " + methodName + " ends" ); return result; } } |
切面类 ValidationAspect.java
1
2
3
4
5
6
7
8
9
10
11
12
|
package com.spring.aop.impl.xml; import java.util.Arrays; import org.aspectj.lang.JoinPoint; public class ValidationAspect { public void validateArgs(JoinPoint joinPoint) { System.out.println( "validate:" + Arrays.asList(joinPoint.getArgs())); } } |
applicationContext-xml.xml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
|
<? 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.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-4.1.xsd"> <!-- 配置bean --> < bean id = "arithmeticCalculator" class = "com.spring.aop.impl.xml.ArithmeticCalculatorImpl" ></ bean > <!-- 配置切面的bean --> < bean id = "loggingAspect" class = "com.spring.aop.impl.xml.LoggingAspect" ></ bean > < bean id = "validationAspect" class = "com.spring.aop.impl.xml.ValidationAspect" ></ bean > <!-- 配置AOP --> < aop:config > <!-- 配置切点表达式 --> < aop:pointcut expression = "execution(* com.spring.aop.impl.xml.ArithmeticCalculator.*(..))" id = "pointcut" /> <!-- 配置切面及通知,使用order指定优先级 --> < aop:aspect ref = "loggingAspect" order = "1" > <!-- 环绕通知 --> <!-- <aop:around method="aroundMethod" pointcut-ref="pointcut"/> --> <!-- 前置通知 --> < aop:before method = "beforeMethod" pointcut-ref = "pointcut" /> <!-- 后置通知 --> < aop:after method = "afterMethod" pointcut-ref = "pointcut" /> <!-- 异常通知 --> < aop:after-throwing method = "afterThrowing" pointcut-ref = "pointcut" throwing = "e" /> <!-- 返回通知 --> < aop:after-returning method = "afterReturnning" pointcut-ref = "pointcut" returning = "result" /> </ aop:aspect > < aop:aspect ref = "validationAspect" order = "2" > <!-- 前置通知 --> < aop:before method = "validateArgs" pointcut-ref = "pointcut" /> </ aop:aspect > </ aop:config > </ beans > |
Main.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
package com.spring.aop.impl.xml; import org.springframework.context.ApplicationContext; import org.springframework.context.support.ClassPathXmlApplicationContext; public class Main { public static void main(String[] args) { //创建spring IOC容器 ApplicationContext applicationContext = new ClassPathXmlApplicationContext( "applicationContext-xml.xml" ); //从IOC容器中获取bean实例 ArithmeticCalculator arithmeticCalculator = applicationContext.getBean(ArithmeticCalculator. class ); int result = arithmeticCalculator.add( 4 , 6 ); System.out.println(result); result = arithmeticCalculator.sub( 4 , 6 ); System.out.println(result); System.out.println(result); result = arithmeticCalculator.mul( 4 , 6 ); System.out.println(result); System.out.println(result); result = arithmeticCalculator.div( 4 , 0 ); System.out.println(result); } } |
源码 http://yunpan.cn/cgsrQHmUvrIQt 提取码 6564
本文出自 “优赛工作室” 博客,请务必保留此出处http://shamrock.blog.51cto.com/2079212/1557743
Spring4学习笔记-AOP(基于配置文件的方式)的更多相关文章
- Spring4学习笔记-AOP
1.加入jar包 com.springsource.org.aopalliance-1.0.0.jar com.springsource.org.aspectj.weaver-1.6.8.RELEAS ...
- Spring(二十):Spring AOP(四):基于配置文件的方式来配置 AOP
基于配置文件的方式来配置 AOP 前边三个章节<Spring(十七):Spring AOP(一):简介>.<Spring(十八):Spring AOP(二):通知(前置.后置.返回. ...
- Spring AOP基于配置文件的面向方法的切面
Spring AOP基于配置文件的面向方法的切面 Spring AOP根据执行的时间点可以分为around.before和after几种方式. around为方法前后均执行 before为方法前执行 ...
- SpringBoot学习笔记:读取配置文件
SpringBoot学习笔记:读取配置文件 配置文件 在以往的项目中,我们主要通过XML文件进行框架配置,业务的相关配置会放在属性文件中,然后通过一个属性读取的工具类来读取配置信息.在SpringBo ...
- .NET Remoting学习笔记(二)激活方式
目录 .NET Remoting学习笔记(一)概念 .NET Remoting学习笔记(二)激活方式 .NET Remoting学习笔记(三)信道 参考:百度百科 ♂风车车.Net 激活方式概念 在 ...
- 【转载】.NET Remoting学习笔记(二)激活方式
目录 .NET Remoting学习笔记(一)概念 .NET Remoting学习笔记(二)激活方式 .NET Remoting学习笔记(三)信道 参考:百度百科 ♂风车车.Net 激活方式概念 在访 ...
- go微服务框架kratos学习笔记四(kratos warden-quickstart warden-direct方式client调用)
目录 go微服务框架kratos学习笔记四(kratos warden-quickstart warden-direct方式client调用) warden direct demo-server gr ...
- 详解AOP——用配置文件的方式实现AOP
AOP概念 1.AOP:面向切面(方面)编程,扩展功能不修改源代码实现 AOP原理 AOP采用横向抽取机制,取代了传统纵向继承体系重复性代码 传统的纵向抽取机制: 横向抽取机制: AOP操作术语 1. ...
- Java学习笔记-多线程-创建线程的方式
创建线程 创建线程的方式: 继承java.lang.Thread 实现java.lang.Runnable接口 所有的线程对象都是Thead及其子类的实例 每个线程完成一定的任务,其实就是一段顺序执行 ...
随机推荐
- Linux I/O复用中select poll epoll模型的介绍及其优缺点的比較
关于I/O多路复用: I/O多路复用(又被称为"事件驱动"),首先要理解的是.操作系统为你提供了一个功能.当你的某个socket可读或者可写的时候.它能够给你一个通知.这样当配合非 ...
- [转]鼠标和键盘模拟API
几乎所有的游戏中都使用了鼠标来改变角色的位置和方向,玩家仅用一个小小的鼠标,就可以使角色畅游天下. 那么,我们如何实现在没有玩家的参与下角色也可以自动行走呢.其实实现这个并不难,仅仅几个Windows ...
- ld -l选项注意事项
在程序中用到某个静态库,使用命令: gcc bin -llibrary.a object.o 结果发现找不到library.a中的某些函数符号 undefine reference to ... 通过 ...
- Apache伪静态Rewrite详解
一.Rewrite规则简介:Rewirte主要的功能就是实现URL的跳转,它的正则表达式是基于 Perl语言.可基于服务器级的(httpd.conf)和目录级的 (.htaccess)两种方式.如果要 ...
- lua 打印 table 拷贝table
-- 打印table function print_lua_table (lua_table, indent) if lua_table == nil or type(lua_table) ~= &q ...
- 用HTML创建表格
本章目标:了解掌握表格的基本结构<table><tr><th><td> 掌握跨行.跨列属性colspan rowspan 掌握表格相关修饰属性borde ...
- Torch-RNN运行过程中的坑 [0](一些基础概念)
0.Lua & LuaJIT简介 Lua 是一种轻量小巧的脚本语言,用标准C语言编写并以源代码形式开放, 其设计目的是为了嵌入应用程序中,从而为应用程序提供灵活的扩展和定制功能. Lua 是巴 ...
- [分享]JavaScript Quick Reference Card
pdf文件:https://files.cnblogs.com/files/MakeView660/JavaScript_Quick_Reference_Card.pdf
- boost数据结构tuple
boost数据结构tuple tuple(元组)定义了一个有固定数目元素的容器,其中每个元素类型可以不相同,这与其它容器有着本质的区别!vector和array虽然可以容纳很多元素,但是元素的类型必须 ...
- VS2008让Release配置也能调试起来~
1.切换当前配置为Release-Win32 2.工程属性->C/C++->General->Debug Information Format 3.工程属性->C/C++-&g ...