spring AOP定义AfterThrowing增加处理实例分析

作者:cakincqm 时间:2021-07-11 14:22:11 

本文实例讲述了spring AOP定义AfterThrowing增加处理。分享给大家供大家参考,具体如下:

一 配置


<?xml version="1.0" encoding="GBK"?>
<beans xmlns="http://www.springframework.org/schema/beans"
  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xmlns:context="http://www.springframework.org/schema/context"
  xmlns:aop="http://www.springframework.org/schema/aop"
  xsi:schemaLocation="http://www.springframework.org/schema/beans
  http://www.springframework.org/schema/beans/spring-beans-4.0.xsd
  http://www.springframework.org/schema/context
  http://www.springframework.org/schema/context/spring-context-4.0.xsd
  http://www.springframework.org/schema/aop
  http://www.springframework.org/schema/aop/spring-aop-4.0.xsd">
  <!-- 指定自动搜索Bean组件、自动搜索切面类 -->
  <context:component-scan
     base-package="org.crazyit.app.service
     ,org.crazyit.app.aspect">
     <context:include-filter type="annotation"
       expression="org.aspectj.lang.annotation.Aspect" />
  </context:component-scan>
  <!-- 启动@AspectJ支持 -->
  <aop:aspectj-autoproxy />
</beans>

二 切面类


package org.crazyit.app.aspect;
import org.aspectj.lang.annotation.*;
import org.aspectj.lang.*;
// 定义一个切面
@Aspect
public class RepairAspect
{
 // 匹配org.crazyit.app.service.impl包下所有类的、
 // 所有方法的执行作为切入点
 @AfterThrowing(throwing="ex"
   , pointcut="execution(* org.crazyit.app.service.impl.*.*(..))")
 // 声明ex时指定的类型会限制目标方法必须抛出指定类型的异常
 // 此处将ex的类型声明为Throwable,意味着对目标方法抛出的异常不加限制
 public void doRecoveryActions(Throwable ex)
 {
   System.out.println("目标方法中抛出的异常:" + ex);
   System.out.println("模拟Advice对异常的修复...");
 }
}

三 接口

Hello


package org.crazyit.app.service;
public interface Hello {
  // 定义一个简单方法,模拟应用中的业务逻辑方法
  void foo();
  // 定义一个addUser()方法,模拟应用中的添加用户的方法
  int addUser(String name, String pass);
}

World


package org.crazyit.app.service;
public interface World {
  // 定义一个简单方法,模拟应用中的业务逻辑方法
  public void bar();
}

四 实现类

HelloImpl


package org.crazyit.app.service.impl;
import org.springframework.stereotype.Component;
import org.crazyit.app.service.*;
@Component("hello")
public class HelloImpl implements Hello
{
 // 定义一个简单方法,模拟应用中的业务逻辑方法
 public void foo()
 {
   System.out.println("执行Hello组件的foo()方法");
 }
 // 定义一个addUser()方法,模拟应用中的添加用户的方法
 public int addUser(String name , String pass)
 {
   System.out.println("执行Hello组件的addUser添加用户:" + name);
   if(name.length() < 3 || name.length() > 10)
   {
     throw new IllegalArgumentException("name参数的长度必须大于3,小于10!");
   }
   return 20;
 }
}

WorldImpl


package org.crazyit.app.service.impl;
import org.springframework.stereotype.Component;
import org.crazyit.app.service.*;
@Component("world")
public class WorldImpl implements World {
 // 定义一个简单方法,模拟应用中的业务逻辑方法
 public void bar() {
   System.out.println("执行World组件的bar()方法");
 }
}

五 测试类


package lee;
import org.springframework.context.*;
import org.springframework.context.support.*;
import org.crazyit.app.service.*;
public class BeanTest {
 public static void main(String[] args) {
   // 创建Spring容器
   ApplicationContext ctx = new ClassPathXmlApplicationContext("beans.xml");
   Hello hello = ctx.getBean("hello", Hello.class);
   hello.foo();
   hello.addUser("悟空", "7788");
   World world = ctx.getBean("world", World.class);
   world.bar();
 }
}

六 测试结果

执行Hello组件的foo()方法
执行Hello组件的addUser添加用户:悟空
目标方法中抛出的异常:java.lang.IllegalArgumentException: name参数的长度必须大于3,小于10!
模拟Advice对异常的修复...
Exception in thread "main" java.lang.IllegalArgumentException:  name参数的长度必须大于3,小于10!
     at  org.crazyit.app.service.impl.HelloImpl.addUser(HelloImpl.java:30)
     at sun.reflect.NativeMethodAccessorImpl.invoke0(Native  Method)
     at  sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
     at  sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
     at java.lang.reflect.Method.invoke(Method.java:498)
     at  org.springframework.aop.support.AopUtils.invokeJoinpointUsingReflection(AopUtils.java:317)
     at  org.springframework.aop.framework.ReflectiveMethodInvocation.invokeJoinpoint(ReflectiveMethodInvocation.java:190)
     at  org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:157)
     at  org.springframework.aop.aspectj.AspectJAfterThrowingAdvice.invoke(AspectJAfterThrowingAdvice.java:58)
     at  org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:179)
     at  org.springframework.aop.interceptor.ExposeInvocationInterceptor.invoke(ExposeInvocationInterceptor.java:92)
     at  org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:179)
     at  org.springframework.aop.framework.JdkDynamicAopProxy.invoke(JdkDynamicAopProxy.java:207)
     at com.sun.proxy.$Proxy7.addUser(Unknown Source)
     at lee.BeanTest.main(BeanTest.java:26)

希望本文所述对大家java程序设计有所帮助。

来源:https://blog.csdn.net/chengqiuming/article/details/101559052

标签:spring,AOP
0
投稿

猜你喜欢

  • unity 文件流读取图片与www读取图片的区别介绍

    2023-08-30 09:10:37
  • Android 自定义AlertDialog对话框样式

    2022-02-06 12:20:07
  • Java开发者就业需要掌握的9大专业技能

    2021-11-13 12:01:54
  • Java 实现微信和支付宝支付功能

    2023-03-08 23:18:04
  • Java实现对两个List快速去重并排序操作示例

    2023-05-02 03:40:14
  • spring aop注解配置代码实例

    2022-02-16 21:13:33
  • Java利用Zxing生成二维码的简单实例

    2023-08-21 13:16:26
  • C#中WebClient实现文件下载

    2022-10-11 18:04:57
  • SpringBoot+Vue.js实现前后端分离的文件上传功能

    2023-08-10 08:11:18
  • 功能强大的TraceId 搭配 ELK使用详解

    2021-09-16 02:26:43
  • 使用@PropertySource读取配置文件通过@Value进行参数注入

    2021-11-21 13:21:03
  • idea 与 maven 使用过程中遇到的问题及解决方案

    2021-10-07 02:34:24
  • springboot做代理分发服务+代理鉴权的实现过程

    2021-06-28 03:22:14
  • 找出链表倒数第n个节点元素的二个方法

    2022-07-20 13:35:40
  • 基于Java实现多线程下载并允许断点续传

    2021-07-19 03:05:52
  • 区分Java中的ArrayList和LinkedList

    2021-05-26 11:09:55
  • Spring的异常重试框架Spring Retry简单配置操作

    2023-11-25 18:27:35
  • c#文件名/路径处理方法示例

    2021-11-28 21:02:40
  • 浅谈JAVA8给我带了什么——流的概念和收集器

    2021-09-24 03:14:04
  • IOS 实现摇一摇的操作

    2023-07-02 13:46:53
  • asp之家 软件编程 m.aspxhome.com