1. 为了在Spring中启动@AspectJ支持,需要在类加载路径下新增两个AspectJ库:aspectjweaver.jar和aspectjrt.jar。除此之外,Spring AOP还需要依赖一个aopalliance.jar包
  2. 定义一个类似ServiceAspect.java这样的切面bean:
  3.  1 package com.hyq.aop;
    2
    3 import org.apache.commons.logging.Log;
    4 import org.apache.commons.logging.LogFactory;
    5 import org.aspectj.lang.JoinPoint;
    6 import org.aspectj.lang.ProceedingJoinPoint;
    7 import org.aspectj.lang.annotation.After;
    8 import org.aspectj.lang.annotation.AfterReturning;
    9 import org.aspectj.lang.annotation.AfterThrowing;
    10 import org.aspectj.lang.annotation.Around;
    11 import org.aspectj.lang.annotation.Aspect;
    12 import org.aspectj.lang.annotation.Before;
    13 import org.aspectj.lang.annotation.Pointcut;
    14 import org.springframework.stereotype.Component;
    15
    16 /**
    17 * 系统服务组件Aspect切面Bean
    18 * @author Shenghany
    19 */
    20 //声明这是一个组件
    21 @Component
    22 //声明这是一个切面Bean
    23 @Aspect
    24 public class ServiceAspect {
    25
    26 private final static Log log = LogFactory.getLog(ServiceAspect.class);
    27
    28 //配置切入点,该方法无方法体,主要为方便同类中其他方法使用此处配置的切入点
    29 @Pointcut("execution(* com.hyq.aop..*(..))")
    30 public void aspect(){ }
    31
    32 /*
    33 * 配置前置通知,使用在方法aspect()上注册的切入点
    34 * 同时接受JoinPoint切入点对象,可以没有该参数
    35 */
    36 @Before("aspect()")
    37 public void before(JoinPoint joinPoint){
    38 System.out.println("执行before.....");
    39 }
    40
    41 //配置后置通知,使用在方法aspect()上注册的切入点
    42 @After("aspect()")
    43 public void after(JoinPoint joinPoint){
    44 System.out.println("执行after.....");
    45 }
    46
    47 //配置环绕通知,使用在方法aspect()上注册的切入点
    48 @Around("aspect()")
    49 public void around(JoinPoint joinPoint){
    50 long start = System.currentTimeMillis();
    51 try {
    52 ((ProceedingJoinPoint) joinPoint).proceed();
    53 long end = System.currentTimeMillis();
    54 if(log.isInfoEnabled()){
    55 log.info("around " + joinPoint + "\tUse time : " + (end - start) + " ms!");
    56 }
    57 } catch (Throwable e) {
    58 long end = System.currentTimeMillis();
    59 if(log.isInfoEnabled()){
    60 log.info("around " + joinPoint + "\tUse time : " + (end - start) + " ms with exception : " + e.getMessage());
    61 }
    62 }
    63 }
    64
    65 //配置后置返回通知,使用在方法aspect()上注册的切入点
    66 @AfterReturning("aspect()")
    67 public void afterReturn(JoinPoint joinPoint){
    68 if(log.isInfoEnabled()){
    69 log.info("afterReturn " + joinPoint);
    70 }
    71 }
    72
    73 //配置抛出异常后通知,使用在方法aspect()上注册的切入点
    74 @AfterThrowing(pointcut="aspect()", throwing="ex")
    75 public void afterThrow(JoinPoint joinPoint, Exception ex){
    76 if(log.isInfoEnabled()){
    77 log.info("afterThrow " + joinPoint + "\t" + ex.getMessage());
    78 }
    79 }
    80
    81 }

    3.定义一个业务组件,如:

  4.  1 package com.hyq.aop;
    2
    3 import org.apache.commons.logging.Log;
    4 import org.apache.commons.logging.LogFactory;
    5 import org.springframework.stereotype.Component;
    6 @Component()
    7 public class UserService {
    8
    9 private final static Log log = LogFactory.getLog(UserService.class);
    10
    11 public User get(long id){
    12 if(log.isInfoEnabled()){
    13 log.info("getUser method . . .");
    14 }
    15 return new User();
    16 }
    17
    18 public void save(User user){
    19 if(log.isInfoEnabled()){
    20 log.info("saveUser method . . .");
    21 }
    22 }
    23
    24 public boolean delete(long id) throws Exception{
    25 if(log.isInfoEnabled()){
    26 log.info("delete method . . .");
    27 throw new Exception("spring aop ThrowAdvice演示");
    28 }
    29 return false;
    30 }
    31
    32 }

    业务组件要用@Component()注解修饰

    4.在bean.xml中加入下面配置:

1 <!-- 激活组件扫描功能,在包com.hyq.aop及其子包下面自动扫描通过注解配置的组件 -->
2 <context:component-scan base-package="com.hyq.aop"/>
3 <!-- 激活自动代理功能 -->
4 <!-- <aop:aspectj-autoproxy proxy-target-class="true"/> -->
5 <aop:aspectj-autoproxy/>

转载:https://www.cnblogs.com/zest/p/5883866.html

Spring AOP基于注解的“零配置”方式实现的更多相关文章

  1. spring-第十七篇之spring AOP基于注解的零配置方式

    1.基于注解的零配置方式 Aspect允许使用注解定义切面.切入点和增强处理,spring框架可以识别并根据这些注解来生成AOP代理.spring只是用了和AspectJ 5一样的注解,但并没有使用A ...

  2. 8 -- 深入使用Spring -- 4...5 AOP代理:基于注解的“零配置”方式

    8.4.5 基于注解的“零配置”方式 AspectJ允许使用注解定义切面.切入点和增强处理,而Spring框架则可识别并根据这些注解来生成AOP代理.Spring只是使用了和AspectJ 5 一样的 ...

  3. 【学习】Spring 的 AOP :基于Annotation 的“零配置”方式

    转自:http://www.cnblogs.com/jbelial/archive/2012/07/20/2539123.html AOP(Aspect Orient Programming ) , ...

  4. 10 Spring框架--基于注解的IOC配置

    1.工程环境搭建 2.基于注解的IOC配置 IOC注解的分类 (1)用于创建对象的 他们的作用就和在XML配置文件中编写一个<bean>标签实现的功能是一样的@Component: 作用: ...

  5. Spring Aop基于注解的实现

    一.AspectOriented Programing,面向切面编程.   AOP主要用于日志记录,性能统计,安全控制(权限控制),事务处理,异常处理等.将日志记录,性能统计,安全控制,事务处理,异常 ...

  6. spring-第十八篇之spring AOP基于XML配置文件的管理方式

    1.在XML配置文件中配置切面.切入点.增强处理.spring-1.5之前只能使用XML Schema方式配置切面.切入点.增强处理. spring配置文件中,所有的切面.切入点.增强处理都必须定义在 ...

  7. spring的基于注解的IOC配置

    1.配置文件配置 <?xml version="1.0" encoding="UTF-8"?><beans xmlns="http: ...

  8. Spring boot 基于注解方式配置datasource

    Spring boot 基于注解方式配置datasource 编辑 ​ Xml配置 我们先来回顾下,使用xml配置数据源. 步骤: 先加载数据库相关配置文件; 配置数据源; 配置sqlSessionF ...

  9. 基于纯Java代码的Spring容器和Web容器零配置的思考和实现(3) - 使用配置

    经过<基于纯Java代码的Spring容器和Web容器零配置的思考和实现(1) - 数据源与事务管理>和<基于纯Java代码的Spring容器和Web容器零配置的思考和实现(2) - ...

随机推荐

  1. OpenStack Mitaka HA部署方案(随笔)

    [Toc] https://github.com/wanstack/AutoMitaka # 亲情奉献安装openstack HA脚本 使用python + shell,完成了基本的核心功能(纯二层的 ...

  2. 【设计模式】calendar的单例需求和实现

    calendar单例需求: 参数:有default的calendar file 1.如果无实例,无参数调用,取default,检查是否合法,存入实例 2.如果无实例,有参数调用,检查是否合法,存入实例 ...

  3. 用 hash 找出指定一个数, 这个数是数组两个值的总和, 找出两个值的坐标

    var twoSum = function(nums, target) { var len = nums.length; var exist = {} //这里利用了hash来存放已知的 exist[ ...

  4. Markdown博文快速转为微信文章

    介绍 技术博文在CSDN上,全是Markdown格式,最近看各位大佬又是个人网站又是个人微信公众号,突然发现: "个人博客小站 + 个人微信公众号 + CSDN + 掘金+ - = 程序员标 ...

  5. js将json数据动态生成表格

    今天开发中遇到需要展示动态数据的问题, 具体要求是后端传来的json字符串,要在前端页面以table表格的形式展示, 其实没啥难的,就是拼接table标签,纯属体力活,于是自己写了个呆萌,保存起来,以 ...

  6. 一个通用Makefile详解

    我们在Linux环境下开发程序,少不了要自己编写Makefile,一个稍微大一些的工程下面都会包含很多.c的源文 件. 如果我们用gcc去一个一个编译每一个源文件的话,效率会低很多,但是如果我们可以写 ...

  7. html中<video>显示视频的时候,MP4的格式问题

    html支持的视频格式:HTML5视频 注意 浏览器对mp4 的编码方式要求的非常严格 视频编码必须是H.264 音频编码必须是: AAC

  8. Tomcat启动超时问题Server Tomcat v7.0 Server at localhost was unable to start within 45 seconds

    使用Eclipse启动Tomcat时出现启动超时的问题如下所示: Server Tomcat v7.0 Server at localhost was unable to start within 4 ...

  9. 复制的web工程为什么不能部署到tomcat

    An existing resource has been found at location D:\apache-tomcat-6.0.18\apache-tomcat-6.0.18\webapps ...

  10. 【转】C# Socket编程(3)编码和解码

    [转自:https://www.cnblogs.com/IPrograming/archive/2012/10/13/CSharp_Socket_3.html] 在网络通信中,很多情况下:比如说QQ聊 ...