Springboot使用Aspect实现切面日志

@Target(ElementType.METHOD)

@Retention(RetentionPolicy.RUNTIME)

@Documented

public @interface SysLog {

String value() default “”;

}

5、声明切面,完成日志记录

以上4点我们的准备工作已经完成。接下来就是重点了

这里需要你对AOP有一定的了解。起码知道切点表达式、环绕通知、前置通知、后置通知等。。。

package com.space.aspect.aspect;

import com.google.gson.Gson;

import com.space.aspect.anno.SysLog;

import com.space.aspect.bo.SysLogBO;

import com.space.aspect.service.SysLogService;

import org.aspectj.lang.ProceedingJoinPoint;

import org.aspectj.lang.annotation.Around;

import org.aspectj.lang.annotation.Aspect;

import org.aspectj.lang.annotation.Pointcut;

import org.aspectj.lang.reflect.MethodSignature;

import org.springframework.beans.factory.annotation.Autowired;

import org.springframework.stereotype.Component;

import java.lang.reflect.Method;

import java.text.SimpleDateFormat;

import java.util.ArrayList;

import java.util.Date;

import java.util.List;

/**

* 系统日志切面

* @author zhuzhe

*/

@Aspect  // 使用@Aspect注解声明一个切面

@Component

public class SysLogAspect {

@Autowired

private SysLogService sysLogService;

/**

* 这里我们使用注解的形式

* 当然,我们也可以通过切点表达式直接指定需要拦截的package,需要拦截的class 以及 method

* 切点表达式:   execution(…)

*/

@Pointcut(“@annotation(com.space.aspect.anno.SysLog)”)

public void logPointCut() {}

/**

* 环绕通知 @Around  , 当然也可以使用 @Before (前置通知)  @After (后置通知)

* @param point

* @return

* @throws Throwable

*/

@Around(“logPointCut()”)

public Object around(ProceedingJoinPoint point) throws Throwable {

long beginTime = System.currentTimeMillis();

Object result = point.proceed();

long time = System.currentTimeMillis() - beginTime;

try {

saveLog(point, time);

} catch (Exception e) {

}

return result;

}

/**

* 保存日志

* @param joinPoint

* @param time

*/

private void saveLog(ProceedingJoinPoint joinPoint, long time) {

MethodSignature signature = (MethodSignature) joinPoint.getSignature();

Method method = signature.getMethod();

SysLogBO sysLogBO = new SysLogBO();

sysLogBO.setExeuTime(time);

SimpleDateFormat dateFormat = new SimpleDateFormat(“yyyy-MM-dd hh:mm:ss”);

sysLogBO.setCreateDate(dateFormat.format(new Date()));

SysLog sysLog = method.getAnnotation(SysLog.class);

if(sysLog != null){

//注解上的描述

sysLogBO.setRemark(sysLog.value());

}

//请求的 类名、方法名

String className = joinPoint.getTarget().getClass().getName();

String methodName = signature.getName();

sysLogBO.setClassName(className);

sysLogBO.setMethodName(methodName);

//请求的参数

Object[] args = joinPoint.getArgs();

try{

List list = new ArrayList();

for (Object o : args) {

list.add(new Gson().toJson(o));

}

sysLogBO.setParams(list.toString());

}catch (Exception e){ }

sysLogService.save(sysLogBO);

}

}

6、测试

接下来,我们就来测试一下吧

package com.space.aspect.controller;

import com.space.aspect.anno.SysLog;

import org.springframework.web.bind.annotation.GetMapping;

import org.springframework.web.bind.annotation.RequestParam;

import org.springframework.web.bind.annotation.RestController;

/**

* @author zhuzhe

*/

@RestController

public class TestController {

@SysLog(“测试”)

@GetMapping(“/test”)

public String test(@RequestParam(“name”) String name){

return name;

}

}

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)

img

面试资料整理汇总

成功从小公司跳槽进蚂蚁定级P7,只因刷了七遍这些面试真题

成功从小公司跳槽进蚂蚁定级P7,只因刷了七遍这些面试真题

这些面试题是我朋友进阿里前狂刷七遍以上的面试资料,由于面试文档很多,内容更多,没有办法一一为大家展示出来,所以只好为大家节选出来了一部分供大家参考。

面试的本质不是考试,而是告诉面试官你会做什么,所以,这些面试资料中提到的技术也是要学会的,不然稍微改动一下你就凉凉了

在这里祝大家能够拿到心仪的offer!
《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》点击传送门即可获取!
(img-BbmMhNsD-1712204178321)]

这些面试题是我朋友进阿里前狂刷七遍以上的面试资料,由于面试文档很多,内容更多,没有办法一一为大家展示出来,所以只好为大家节选出来了一部分供大家参考。

面试的本质不是考试,而是告诉面试官你会做什么,所以,这些面试资料中提到的技术也是要学会的,不然稍微改动一下你就凉凉了

在这里祝大家能够拿到心仪的offer!
《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》点击传送门即可获取!

Spring Boot 提供了很好的支持来实现面向切面编程。面向切面编程(AOP)是一种编程范式,它允许将横跨多个业务逻辑的功能(例如日志记录、事务管理等)从应用程序的核心业务逻辑中分离出来,以提高代码的可重用性、模块化和可维护性。 在 Spring Boot 中,你可以使用 Spring AOP 来实现面向切面编程。Spring AOP 基于代理模式,通过在目标对象上动态生成一个代理对象来实现切面功能。Spring AOP 提供了很多注解来定义切面、切入点、通知等。 下面是一个简单的面向切面编程的示例,它演示了如何在 Spring Boot使用 AOP 记录方法的执行时间: 1. 定义一个切面类,使用 @Aspect 注解标记,定义一个切入点,使用 @Pointcut 注解标记: ``` @Aspect @Component public class LogAspect { @Pointcut("execution(* com.example.demo.service.*.*(..))") public void servicePointcut() { } @Around("servicePointcut()") public Object logExecutionTime(ProceedingJoinPoint joinPoint) throws Throwable { long startTime = System.currentTimeMillis(); Object proceed = joinPoint.proceed(); System.out.println(joinPoint.getSignature().getName() + " executed in " + (System.currentTimeMillis() - startTime) + "ms"); return proceed; } } ``` 2. 在应用程序的启动类上添加 @EnableAspectJAutoProxy 注解来启用 AOP: ``` @SpringBootApplication @EnableAspectJAutoProxy public class Application { public static void main(String[] args) { SpringApplication.run(Application.class, args); } } ``` 这样,在调用 com.example.demo.service 包下的任何方法时,LogAspect 类中定义的 logExecutionTime 方法都会被调用,记录方法的执行时间。 以上是一个简单的面向切面编程示例。在实际应用中,你可以使用 AOP 来实现很多功能,例如事务管理、安全控制等。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值