Spring AOP(XML后置+异常通知)

后置通知


AuditAspect.java

java 复制代码
package com.hk.eshop.aop;


import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.Signature;

public class AuditAspect {
    public void audit(JoinPoint joinPoint,String returnValue)
    {
        Object[] args = joinPoint.getArgs();
        Signature sig = joinPoint.getSignature();
        System.out.println("触发方法......"+sig.getName());
        System.out.println("方法审计开始......");
        for(int i=1;i<=args.length;i++)
            System.out.println("第"+i+"个参数="+args[i-1]);
        System.out.println("方法审计结束......");
        System.out.println("切入点表达式......"+joinPoint.toString());
        System.out.println("目标方法返回值......"+returnValue);
    }
}

UserMng.java

java 复制代码
package com.hk.eshop.aop;

import com.hk.eshop.java.IUserMng;

public class UserMng{
    public String save(String id, String name) {
        System.out.println("save() id="+id+",name="+name);
        return "save() id="+id+",name="+name;
    }

    public String find(String id) {
        System.out.println("find() id="+id);
        return "find() id="+id;
    }
}

异常通知




异常切面代码

java 复制代码
package com.hk.eshop.aop;


import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.Signature;

public class AuditOrgAspect {
    public void audit(JoinPoint joinPoint,Throwable throwValue)
    {
        Object[] args = joinPoint.getArgs();
        Signature sig = joinPoint.getSignature();
        System.out.println("触发方法......"+sig.getName());
        System.out.println("方法审计开始......");
        for(int i=1;i<=args.length;i++)
            System.out.println("第"+i+"个参数="+args[i-1]);
        System.out.println("方法审计结束......");
        System.out.println("切入点表达式......"+joinPoint.toString());
        System.out.println("目标方法抛出异常......"+throwValue);
    }
}


package com.hk.eshop.aop;

public class OrgExistException extends Exception{
    public OrgExistException(String msg)
    {
        super(msg);
    }
}


package com.hk.eshop.aop;

public class OrgNotFoundException extends Exception{
    public OrgNotFoundException(String msg)
    {
        super(msg);
    }
}


package com.hk.eshop.aop;

public class OrgMng {
    public String save(String id, String name) throws OrgExistException{
        if(id.equals("root"))
            throw new OrgExistException("Root Org exists...");
        System.out.println("save() id="+id+",name="+name);
        return "save() id="+id+",name="+name;
    }

    public String find(String id) throws OrgNotFoundException{
        if(id.equals("root"))
            throw new OrgNotFoundException("Root Org no found...");
        System.out.println("find() id="+id);
        return "find() id="+id;
    }
}



package com.hk.eshop.aop;

import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;

public class Main {
    public static void main( String[] args )
    {
        ApplicationContext ctx = new ClassPathXmlApplicationContext("beans.xml");
        UserMng umng = (UserMng)ctx.getBean("userMng");
        umng.save("1","Java");
        umng.find("2");
        System.out.println("############################################");
        try {
            OrgMng omng = (OrgMng) ctx.getBean("orgMng");
            omng.save("root", "Java");
            omng.find("root");
        }
        catch (Exception e)
        {
            e.printStackTrace();
        }
    }
}
相关推荐
莫爷1 小时前
JSON vs XML vs YAML 深度对比:如何选择合适的数据格式?
xml·前端·json
jgbazsh1 小时前
Spring中把一个bean对象交给Spring容器管理的三种方式
java·后端·spring
Network porter1 小时前
IDEA2025(2025.2)都更新了什么???
java·intellij-idea·idea
twc8291 小时前
不可言说的知识:AI时代软件工程的核心传递问题
java·人工智能·大模型·软件工程·知识工程
华仔啊2 小时前
前端不懂 Java?后端怕 CSS?这套AI全栈方案专治各种偏科
java·前端·后端
今天和Aboo结婚了吗3 小时前
【Broker一重启消息没了:一次RabbitMQ非持久化+没开Confirm的血亏事故】
java·rabbitmq·messagequeue·bug排查
daidaidaiyu9 小时前
一文学习 工作流开发 BPMN、 Flowable
java
SuniaWang10 小时前
《Spring AI + 大模型全栈实战》学习手册系列 · 专题六:《Vue3 前端开发实战:打造企业级 RAG 问答界面》
java·前端·人工智能·spring boot·后端·spring·架构
sheji341610 小时前
【开题答辩全过程】以 基于springboot的扶贫系统为例,包含答辩的问题和答案
java·spring boot·后端