java 日志导入mysql_java注解日志记录到数据库

packagecom.spring4all.config;importcom.alibaba.fastjson.JSON;importcom.spring4all.config.intercepors.MyLog;importcom.spring4all.entity.SysLogDO;importcom.spring4all.service.SysLogService;importorg.aspectj.lang.JoinPoint;importorg.aspectj.lang.annotation.AfterReturning;importorg.aspectj.lang.annotation.Aspect;importorg.aspectj.lang.annotation.Pointcut;importorg.aspectj.lang.reflect.MethodSignature;importorg.springframework.beans.factory.annotation.Autowired;importorg.springframework.stereotype.Component;importjavax.servlet.http.HttpServletRequest;importjava.lang.reflect.Method;importjava.util.Date;/***@authorshafei

*@version1.0

* @date 10:08 2019/9/7

* fun:*/@Aspect

@Componentpublic classSysLogAspect {

@AutowiredprivateSysLogService sysLogService;//定义切点 @Pointcut//在注解的位置切入代码

@Pointcut("@annotation( com.spring4all.config.intercepors.MyLog)")public voidlogPoinCut() {

}//切面 配置通知

@AfterReturning("logPoinCut()")public voidsaveSysLog(JoinPoint joinPoint) {

System.out.println("切面。。。。。");//保存日志

SysLogDO sysLog = newSysLogDO();//从切面织入点处通过反射机制获取织入点处的方法

MethodSignature signature =(MethodSignature) joinPoint.getSignature();//获取切入点所在的方法

Method method =signature.getMethod();//获取操作

MyLog myLog = method.getAnnotation(MyLog.class);if (myLog != null) {

String value=myLog.value();

sysLog.setOperation(value);//保存获取的操作

}//获取请求的类名

String className =joinPoint.getTarget().getClass().getName();//获取请求的方法名

String methodName =method.getName();

sysLog.setMethod(className+ "." +methodName);//请求的参数

Object[] args =joinPoint.getArgs();//将参数所在的数组转换成json

String params =JSON.toJSONString(args);

sysLog.setParams(params);

sysLog.setCreateDate(newDate());//获取用户名

sysLog.setUsername("shafei");//获取用户ip地址//HttpServletRequest request = HttpContextUtils.getHttpServletRequest();

sysLog.setIp("192.168.3.11");//调用service保存SysLog实体类到数据库//sysLogService.save(sysLog);

System.out.println("将日志记录到数据库");

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值