//获取请求

package org.nxubay.flux.plugins.modules.log.AutoLog;


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.nxubay.flux.plugins.async.task.GetOrderTask;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
import org.springframework.web.context.request.RequestContextHolder;
import org.springframework.web.context.request.ServletRequestAttributes;

import javax.servlet.http.HttpServletRequest;
import java.util.Objects;

/*
        系统操作日志
 */
@Component
@Aspect
public class notes {

   @Autowired
    private GetOrderTask getOrderTask;

    @Pointcut("@annotation(org.nxubay.flux.plugins.modules.log.AutoLog.NoteLog)")
    public void logPointCut() {
    System.out.println("xxx");
    }
    @Around("logPointCut()")
    public Object around(ProceedingJoinPoint point) throws Throwable {
        //获取请求
        ServletRequestAttributes requestAttributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();
        HttpServletRequest request = Objects.requireNonNull(requestAttributes).getRequest();
       long beginTime = System.currentTimeMillis();
        //执行方法
        Object result = point.proceed();
        //执行时长(毫秒)
        long time = System.currentTimeMillis() - beginTime;
        //保存日志
        getOrderTask.saveSysLog(point, time,request);
        return result;
    }

}

package org.nxubay.flux.plugins.modules.log.AutoLog;

import java.lang.annotation.*;
/*
@Retention作用是定义被它所注解的注解保留多久,一共有三种策略,定义在RetentionPolicy枚举中.

从注释上看:

source:注解只保留在源文件,当Java文件编译成class文件的时候,注解被遗弃;被编译器忽略

class:注解被保留到class文件,但jvm加载class文件时候被遗弃,这是默认的生命周期

runtime:注解不仅被保存到class文件中,jvm加载class文件之后,仍然存在

//target主要是声明一个新的注解,自定义一个新的注解,target后面是新注解的范围,//ElementType.type用在类上,ElementType.METHOD用在方法上
 */
@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface NoteLog {
    /**
     * 日志内容
     *
     * @return
     */
    String value() default "";
//    /**
//     * 日志类型
//     *
//     * @return 0:操作日志;1:登录日志;2:定时任务;
//     */
//    int logType() default CommonConstant.LOG_TYPE_2;
    /**
     * 操作日志类型
     *
     * @return 1,登录日志 2,操作日志
     */
    int operateType() default 0;
}

package org.nxubay.flux.plugins.async.task;

import cn.hutool.core.util.IdUtil;
import org.apache.catalina.util.RequestUtil;
import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.reflect.MethodSignature;
import org.jeecg.common.util.RedisUtil;
import org.jeecg.common.util.SpringContextUtils;
import org.nxubay.flux.plugins.modules.log.AutoLog.NoteLog;

import org.nxubay.flux.plugins.modules.log.entity.MethodLog;
import org.nxubay.flux.plugins.modules.log.entity.OperateLog;
import org.nxubay.flux.plugins.modules.log.entity.PublicCom;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.scheduling.annotation.Async;
import org.springframework.scheduling.annotation.EnableAsync;
import org.springframework.stereotype.Component;
import org.springframework.stereotype.Service;
import org.springframework.web.context.request.RequestAttributes;
import org.springframework.web.context.request.RequestContextHolder;
import org.springframework.web.context.request.ServletRequestAttributes;
import org.springframework.web.multipart.MultipartHttpServletRequest;
import org.springframework.web.multipart.MultipartResolver;
import org.springframework.web.multipart.commons.CommonsMultipartResolver;

import javax.servlet.http.HttpServletRequest;
import java.lang.reflect.Method;
import java.time.LocalDateTime;
import java.util.List;


@Component
@EnableAsync
@Async
public class GetOrderTask extends PublicCom {



    public void saveSysLog(ProceedingJoinPoint joinPoint, long time,HttpServletRequest request) {
        MethodSignature signature = (MethodSignature) joinPoint.getSignature();
        Method method = signature.getMethod();
        NoteLog syslog2 = method.getAnnotation(NoteLog.class);//获取注解参数
        //joinPoint
        //HttpServletRequest request2 = RequestUtils.getHttpServletRequest();
       // HttpServletRequest request = ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes()).getRequest();//获取request
//        HttpServletRequest request2 = ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes()).getRequest();
//        MultipartResolver resolver = new CommonsMultipartResolver(request2.getSession().getServletContext());
//        MultipartHttpServletRequest request = resolver.resolveMultipart(request2);
        System.out.println("66666666");
        Object[] args = joinPoint.getArgs();
        iOperateLogService.save(new OperateLog()
                .setMethod(signature.getMethod().getName())
                .setRequestParam(syslog2.toString())
                .setLogContent(syslog2.value())
                .setLogType(syslog2.operateType())
                .setRequestUrl(request.getRequestURL().toString())
                .setIp(request.getRemoteAddr())
                .setCostTime(time)
                .setId(IdUtil.simpleUUID())
                .setCreateTime(LocalDateTime.now())
        );
        System.out.println("setMethod:"+signature.getMethod().getName()+"==setRequestParam:"+syslog2.toString()+"setLogContent:"+
                syslog2.value()+"===setLogType:"+syslog2.operateType()+"===setRequestUrl:"+
                "setIp:"+request.getRemoteAddr()+"==setCostTime:"+time+"===setId==:"+IdUtil.simpleUUID()+"===setCreateTime:"+LocalDateTime.now());

    }
    public void publicsaveSysLog(List<String> list) {
        StringBuilder sb = null;
        for(String  d : list ){
            sb.append(d);
        }
        HttpServletRequest request = ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes()).getRequest();
        iMethodLogService.save(new MethodLog().
                setMethod(sb.toString())
                .setUpdateTime(LocalDateTime.now())
        );


    }


}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值