Spring 中aop切面注解实现
spring中aop的注解实现方式简单实例
上篇中我们讲到spring的xml实现,这里我们讲讲使用注解如何实现aop呢。前面已经讲过aop的简单理解了,这里就不在赘述了。
注解方式实现aop我们主要分为如下几个步骤(自己整理的,有更好的方法的话,欢迎交流codecjh@163.com):
1.在切面类(为切点服务的类)前用@Aspect注释修饰,声明为一个切面类。
2.用@Pointcut注释声明一个切点,目的是为了告诉切面,谁是它的服务对象。(此注释修饰的方法的方法体为空,不需要写功能比如 public void say(){};就可以了,方法名可以被候命的具体服务功能所以引用,它可以被理解为切点对象的一个代理对象方法)
3.在对应的方法前用对应的通知类型注释修饰,将对应的方法声明称一个切面功能,为了切点而服务
4.在spring配置文件中开启aop注释自动代理。如:<aop:aspectj-autoproxy/>
这样讲可能还是很抽象,那么,废话不多说,我们代码说话,代码如下:
骑士类:(看过上一篇内容的就知道骑士是什么东西了,嘿嘿嘿)

- 1 package com.cjh.aop2;
- 2
- 3 import org.springframework.stereotype.Component;
- 4
- 5 /**
- 6 * @author 古斌
- 7 *
- 9 */
- 10 @Component("knight")
- 11 public class BraveKnight {
- 12 public void saying(){
- 13 System.out.println("我是骑士..(切点方法)");
- 14 }
- 15 }

切面类:(注释主要在这里体现)

- 1 package com.cjh.aop2;
- 2
- 3 import org.aspectj.lang.ProceedingJoinPoint;
- 4 import org.aspectj.lang.annotation.After;
- 5 import org.aspectj.lang.annotation.Around;
- 6 import org.aspectj.lang.annotation.Aspect;
- 7 import org.aspectj.lang.annotation.Before;
- 8 import org.aspectj.lang.annotation.Pointcut;
- 9 import org.springframework.stereotype.Component;
- 10
- 11 /**
- 15 */
@AspectJ提供不同的通知类型
····@Before前置通知,相当于BeforeAdvice
····@AfterReturning后置通知,相当于AfterReturningAdvice
····@Around环绕通知,相当于MethodInterceptor
····@AfterThrowing抛出通知,相当于ThrowAdvice
····@After最终final通知,不管是否异常,该通知都会执行
- 16 /**
- 17 * 注解方式声明aop
- 18 * 1.用@Aspect注解将类声明为切面(如果用@Component("")注解注释为一个bean对象,那么就要在spring配置文件中开启注解扫描,<context:component-scan base-package="com.cjh.aop2"/>
- 19 * 否则要在spring配置文件中声明一个bean对象)
- 20 * 2.在切面需要实现相应方法的前面加上相应的注释,也就是通知类型。
- 21 * 3.此处有环绕通知,环绕通知方法一定要有ProceedingJoinPoint类型的参数传入,然后执行对应的proceed()方法,环绕才能实现。
- 22 */
- 23 @Component("annotationTest")
- 24 @Aspect
- 25 public class AnnotationTest {
- 26 //定义切点
- 27 @Pointcut("execution(* *.saying(..))")
- 28 public void sayings(){}
- 29 /**
- 30 * 前置通知(注解中的sayings()方法,其实就是上面定义pointcut切点注解所修饰的方法名,那只是个代理对象,不需要写具体方法,
- 31 * 相当于xml声明切面的id名,如下,相当于id="embark",用于供其他通知类型引用)
- 32 * <aop:config>
- 33 <aop:aspect ref="mistrel">
- 34 <!-- 定义切点 -->
- 35 <aop:pointcut expression="execution(* *.saying(..))" id="embark"/>
- 36 <!-- 声明前置通知 (在切点方法被执行前调用) -->
- 37 <aop:before method="beforSay" pointcut-ref="embark"/>
- 38 <!-- 声明后置通知 (在切点方法被执行后调用) -->
- 39 <aop:after method="afterSay" pointcut-ref="embark"/>
- 40 </aop:aspect>
- 41 </aop:config>
- 42 */
- 43 @Before("sayings()")
- 44 public void sayHello(){
- 45 System.out.println("注解类型前置通知");
- 46 }
- 47 //后置通知
- 48 @After("sayings()")
- 49 public void sayGoodbey(){
- 50 System.out.println("注解类型后置通知");
- 51 }
- 52 //环绕通知。注意要有ProceedingJoinPoint参数传入。
- 53 @Around("sayings()")
- 54 public void sayAround(ProceedingJoinPoint pjp) throws Throwable{
- 55 System.out.println("注解类型环绕通知..环绕前");
- 56 pjp.proceed();//执行方法
- 57 System.out.println("注解类型环绕通知..环绕后");
- 58 }
- 59 }

spring配置文件:

- 1 <?xml version="1.0" encoding="UTF-8"?>
- 2 <beans xmlns="http://www.springframework.org/schema/beans"
- 3 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
- 4 xmlns:context="http://www.springframework.org/schema/context"
- 5 xmlns:aop="http://www.springframework.org/schema/aop"
- 6 xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
- 7 http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-4.3.xsd
- 8 http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.3.xsd">
- 9 <!-- 开启注解扫描 -->
- 10 <context:component-scan base-package="com.cjh.aop2"/>
- 11 <!-- 开启aop注解方式,此步骤s不能少,这样java类中的aop注解才会生效 -->
- 12 <aop:aspectj-autoproxy/>
- 13 </beans>

测试代码:

- 1 package com.cjh.aop2;
- 2
- 3 import org.springframework.context.ApplicationContext;
- 4 import org.springframework.context.support.ClassPathXmlApplicationContext;
- 5
- 6 /**
- 7 *
- 11 */
- 12 public class Test {
- 13 public static void main(String[] args) {
- 14 ApplicationContext ac = new ClassPathXmlApplicationContext("com/cjh/aop2/beans.xml");
- 15 BraveKnight br = (BraveKnight) ac.getBean("knight");
- 16 br.saying();
- 17 }
- 18 }

运行结果:
注解类型环绕通知..环绕前
注解类型前置通知
我是骑士..(切点方法)
注解类型环绕通知..环绕后
注解类型后置通知
========================分割线===================================
因为使用了注解方式,所以配置文件少了很多内容,只需要一句<context:component-scan base-package="com.cjh.aop2"/>声明要扫描的包,框架会自动扫描注释并生成bean对象。有个@Component("knight")这个注释,和<bean id="knight" class="com.cjh.aop2.BraveKnight"/>这个配置时一样的意思,框架会自动识别并创建名为knight的BraveKnight对象。所以有了注释,只需要开启注释扫描配置就好了,无需再做相同的bean配置。
如果运行过程中出现Spring aop : error at ::0 can't find referenced pointcut sleepPonit的错误,那么很可能是spring的包的版本问题,
我用的是spring4的版本,然后还需要加aspectjrt-1.7.4.jar和aspectjweaver-1.7.4.jar两个包,云盘地址:链接:http://pan.baidu.com/s/1qXQurO4 密码:nc4i
工程目录如下:(打码码的类不用管,只是为了不为大家造成误导,所以划掉了)
通知注解类型如下:
上图:
XML的配置:
切入点:
切面:
测试
Spring 中aop切面注解实现的更多相关文章
- 浅谈spring中AOP以及spring中AOP的注解方式
AOP(Aspect Oriented Programming):AOP的专业术语是"面向切面编程" 什么是面向切面编程,我的理解就是:在不修改源代码的情况下增强功能.好了,下面在 ...
- spring中aop的注解实现方式简单实例
上篇中我们讲到spring的xml实现,这里我们讲讲使用注解如何实现aop呢.前面已经讲过aop的简单理解了,这里就不在赘述了. 注解方式实现aop我们主要分为如下几个步骤(自己整理的,有更好的方法的 ...
- Spring中AOP切面编程学习笔记
注解方式实现aop我们主要分为如下几个步骤: 1.在切面类(为切点服务的类)前用@Aspect注释修饰,声明为一个切面类. 2.用@Pointcut注释声明一个切点,目的是为了告诉切面,谁是它的服务对 ...
- spring 中aop 切面实战
切面相关注解: @Aspect : 声明该类为一个注解类 @Pointcut : 定义一个切点 @Before : 在切点之前执行 @After : 在切点之后执行 不管目标方法是否执行成功 @Aft ...
- Spring中AOP简介与切面编程的使用
Spring中AOP简介与使用 什么是AOP? Aspect Oriented Programming(AOP),多译作 "面向切面编程",也就是说,对一段程序,从侧面插入,进行操 ...
- Spring AOP——Spring 中面向切面编程
前面两篇文章记录了 Spring IOC 的相关知识,本文记录 Spring 中的另一特性 AOP 相关知识. 部分参考资料: <Spring实战(第4版)> <轻量级 JavaEE ...
- Spring中AOP原理,源码学习笔记
一.AOP(面向切面编程):通过预编译和运行期动态代理的方式在不改变代码的情况下给程序动态的添加一些功能.利用AOP可以对应用程序的各个部分进行隔离,在Spring中AOP主要用来分离业务逻辑和系统级 ...
- 框架源码系列十:Spring AOP(AOP的核心概念回顾、Spring中AOP的用法、Spring AOP 源码学习)
一.AOP的核心概念回顾 https://docs.spring.io/spring/docs/5.1.3.RELEASE/spring-framework-reference/core.html#a ...
- Spring中AOP相关源码解析
前言 在Spring中AOP是我们使用的非常频繁的一个特性.通过AOP我们可以补足一些面向对象编程中不足或难以实现的部分. AOP 前置理论 首先在学习源码之前我们需要了解关于AOP的相关概念如切点切 ...
随机推荐
- IntelliJ IDEA—IDEA2018.1激活方式
前言 以前用过2015的版本,后面就没有使用了,现在又重新用起来了,突然发现激活好难,通过网上找破解方式,总算找到了一种可以实现破解的方法了.. 破解方式 本人使用的是使用破解补丁的方式实现破解的,此 ...
- Xcode 中设置部分文件ARC支持
ARC是什么 ARC是iOS 5推出的新功能,全称叫 ARC(Automatic Reference Counting).简单地说,就是代码中自动加入了retain/release,原先需要手动添加的 ...
- Mybatis之XML使用Enum枚举传递数据
在Mybatis中,处理枚举类的TypeHandler有两个: EnumTypeHandler: 用于保存枚举名 EnumOrdinalTypeHandler: 用于保存枚举的序号. 在实际项目中,以 ...
- Linux学习-linux系统下python升级到python3.6步骤详解,以及遇到的问题解决
说明:一般linux会自带pyhton2.7 1.首先下载源tar包 可利用linux自带下载工具wget下载,如下所示: wget http://www.python.org/ftp/python/ ...
- 2015年传智播客JavaEE 第168期就业班视频教程day45-ERP项目-01 05-主线流程
采购管理 销售管理 采购退货管理 销售退货管理 老师的采购单的审核是分三级审核的,如果这个单子是个普通单子,那么审核一下就完了,如果这个单子超过100万,需要二级领导审核,如果这个单子超过500万, ...
- php之trait 个人笔记
自从 php 5.4 起 实现了一种代码复用的方式(tarit) 类似 class 但是用tarit 写的类 不能被实例化 和继承.现在来看看他的用法 <?php trait A{ publi ...
- linux 安装php7 Nginx
这里 记录下 本屌安装linux 下安装php7 即遇到的问题. wget http://cn2.php.NET/distributions/php-7.0.4.tar.gz tar zxvf ph ...
- 解决 Laravel try catch 不工作的问题
最近再用laravel框架发现,try catch用了没有效果,不能捕获异常, 然后在think框架里也试了一下,发现竟然也不可以! [php] view plain copy try{ $i = ...
- 一次清理Hbase的oldWALs的过程
HBase版本:1.3.1 Hadoop版本:2.7.1 Zookeeper版本:3.4.6 --------------------------------- 检查线上业务系统的磁盘空间, 发现HD ...
- c# 调用外包程序 等待处理完成结果
string root = @"J:\yaoqianshu"; string pythonPath = "解压缩拷贝启动动画测试(新).py"; string ...