AOP-@Aspect:系统日志实例

一、interface

/**
 * 系统日志注解
 */
@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface SysLog {
    String value() default "";
}

二、Aspect

/**
 * 系统日志,切面处理类
 */
@Aspect
@Component
@Order()
public class SysLogAspect {
    @Pointcut("@annotation(com.***.SysLog)")
    public void logPointCut() {

    }
    @Around("logPointCut()")
    public Object around(ProceedingJoinPoint point) throws Throwable {
        long beginTime = System.currentTimeMillis();
        //执行方法
        Object result = point.proceed();
        //执行时长(毫秒)
        long time = System.currentTimeMillis() - beginTime;

        //保存日志
        saveSysLog(point, time);

        return result;
    }
private void saveSysLog(ProceedingJoinPoint joinPoint, long time) {
        MethodSignature signature = (MethodSignature) joinPoint.getSignature();
        Method method = signature.getMethod();

        SysLogDo sysLog = new SysLogDo();
        SysLog syslog = method.getAnnotation(SysLog.class);

        //请求的方法名
        String className = joinPoint.getTarget().getClass().getName();
        String methodName = signature.getName();
        sysLog.setMethod(className + "." + methodName + "()");

        //请求的参数
        Object[] args = joinPoint.getArgs();
        try{
            String params = JSON.toJSONString(args[0]);
            sysLog.setParams(params);
            sysLog.setContent(syslog.value()+":"+params);
        }catch (Exception e){

        }

        //获取request
        HttpServletRequest request = HttpContextUtils.getHttpServletRequest();
        //设置IP地址
        sysLog.setIp(IPUtils.getIpAddr(request));

		//TODO 日志存储
    }
}

二、Controller

@RestController
@RequestMapping("/R")
public class RController {
    @SysLog("新增R")
    @RequestMapping(value = "/add", method = RequestMethod.POST)
    @ResponseBody
    public BaseResponse addR(@RequestBody RFrom rFrom) {
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Spring AOP是Spring框架的一部分,主要用于在应用程序的不同部分之间进行面向切面编程(AOP)。AOP是一种编程范式,可以将应用程序的关注点分离,使应用程序更具可重用性和可维护性。 Spring AOP使用代理模式在运行时织入额外的功能,可以在方法调用前后、异常处理等方面添加额外的逻辑。使用Spring AOP可以将应用程序的关注点(如事务处理、日志记录等)分离出来,从而提高应用程序的可维护性和可重用性。 Spring AOP支持使用AspectJ注解和XML配置两种方式来定义切面。Spring AOP还提供了一个强大的表达式语言(Spring Expression Language,简称SpEL),用于在运行时动态地匹配连接点。 总的来说,Spring AOP是一个非常强大的AOP框架,可以帮助我们更好的管理应用程序的关注点,提高应用程序的可维护性和可重用性。 ### 回答2: Spring AOP(面向切面编程)是Spring框架的一个核心模块,用于实现跨应用程序模块的关注点分离。它通过在系统中将横切关注点从业务逻辑中分离出来,实现了代码的重用性、可维护性和扩展性。 Spring AOP基于代理模式,通过动态代理技术在运行时将通用的横切关注点织入目标对象中,从而实现了对目标对象方法的拦截和增强。Spring AOP主要通过使用切面、切点、通知和连接点等概念来实现。 - 切面(Aspect):切面是一个模块,它包含了一组与横切关注点相关的通知和切点。通常,一个应用程序由多个切面组成,每个切面负责某个特定的关注点。比如,日志记录、性能监控等都可以作为切面。 - 切点(Pointcut):切点定义了在哪些目标对象方法上应用通知。它使用表达式来匹配目标对象中的方法。比如,通过使用通配符等方式,我们可以定义一个切点来匹配所有的Service层方法。 - 通知(Advice):通知定义了在切点上执行的行为。Spring AOP提供了五种类型的通知:前置通知(Before)、后置通知(AfterReturning)、异常通知(AfterThrowing)、最终通知(After)和环绕通知(Around)。通过在切面中配置不同类型的通知,我们可以在目标对象方法的不同执行阶段执行相应的操作。 - 连接点(Joinpoint):连接点是在目标对象中匹配到切点的特定位置,比如方法的调用、方法的返回等。在连接点上,可以执行相应的通知。 Spring AOP的主要优势是它能够将关注点分离,使开发人员更关注业务逻辑而不是横切关注点的实现。通过使用Spring AOP,我们可以实现日志记录、事务管理、性能监控等与业务逻辑无关的功能,增加了代码的可维护性和可重用性。此外,Spring AOP还提供了灵活的配置方式,可以使用XML配置或基于注解的方式来定义切面和通知,使代码更加简洁和易于理解。 总之,Spring AOP是Spring框架中实现面向切面编程的核心模块,通过在运行时动态生成代理对象,实现了对目标对象方法的拦截和增强。它通过将通用的横切关注点从业务逻辑中抽离出来,提高了代码的可维护性和可重用性。 ### 回答3: Spring AOP(Aspect-Oriented Programming)是Spring框架中的一个重要模块,用于实现面向切面编程的功能。它通过在不修改原有代码的情况下,将横切关注点(如日志记录、安全检查、事务管理等)从业务逻辑中分离出来,从而提高系统的可维护性和可重用性。 Spring AOP的核心原理是基于动态代理技术,通过在运行时动态生成代理对象来实现AOP功能。它主要由以下几个核心概念组成: 1. 切面(Aspect):是对一个特定横切关注点的抽象描述,它包含了一组通知(Advice)和一个切点(Pointcut)。通知定义了在切点处执行的具体操作,切点定义了在应用程序中哪些位置应该触发通知。 2. 连接点(Join point):是在程序运行过程中,符合切点定义的特定位置,如方法调用、异常抛出等。Spring AOP仅支持方法级别的切点。 3. 通知(Advice):是在连接点处执行的具体操作,包括前置通知(Before)、后置通知(After)、返回通知(AfterReturning)、异常通知(AfterThrowing)和环绕通知(Around)等。它们分别在连接点的不同位置执行,实现不同的横切关注点功能。 4. 切点表达式(Pointcut Expression):是一个表达式,用于匹配特定的切点位置。Spring AOP支持使用AspectJ风格的切点表达式语法。 Spring AOP的应用步骤如下: 1. 定义切面类,包含通知和切点的定义。 2. 配置切面,通过XML配置或基于注解的方式将切面配置到Spring容器中。 3. 定义目标类,即需要被代理的类。 4. 配置代理,通过XML配置或基于注解的方式将目标类与切面关联起来。 5. 启动Spring容器,自动完成代理的实例化和连接点的绑定。 6. 运行程序,当连接点满足切点定义时,代理会根据定义的通知类型执行相应的操作。 总之,Spring AOP是一种强大的横切关注点分离工具,它通过代理机制实现对目标类的增强,使得系统的关注点分离更加灵活和简单。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值