完成操作日志的存储

pull/2/head
YunaiV 2021-01-17 01:21:54 +08:00
parent ec8f181f2f
commit 30076f6472
7 changed files with 82 additions and 30 deletions

View File

@ -11,7 +11,7 @@
Target Server Version : 50718 Target Server Version : 50718
File Encoding : 65001 File Encoding : 65001
Date: 14/01/2021 21:27:23 Date: 17/01/2021 01:21:15
*/ */
SET NAMES utf8mb4; SET NAMES utf8mb4;
@ -262,28 +262,36 @@ CREATE TABLE `sys_notice` (
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8mb4 COMMENT='通知公告表'; ) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8mb4 COMMENT='通知公告表';
-- ---------------------------- -- ----------------------------
-- Table structure for sys_oper_log -- Table structure for sys_operate_log
-- ---------------------------- -- ----------------------------
DROP TABLE IF EXISTS `sys_oper_log`; DROP TABLE IF EXISTS `sys_operate_log`;
CREATE TABLE `sys_oper_log` ( CREATE TABLE `sys_operate_log` (
`oper_id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '日志主键', `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '日志主键',
`title` varchar(50) DEFAULT '' COMMENT '模块标题', `trace_id` varchar(64) NOT NULL DEFAULT '' COMMENT '链路追踪编号',
`business_type` int(2) DEFAULT '0' COMMENT '业务类型0其它 1新增 2修改 3删除', `user_id` bigint(20) NOT NULL COMMENT '用户编号',
`method` varchar(100) DEFAULT '' COMMENT '方法名称', `module` varchar(50) NOT NULL COMMENT '模块标题',
`request_method` varchar(10) DEFAULT '' COMMENT '请求方式', `name` varchar(50) NOT NULL COMMENT '操作名',
`operator_type` int(1) DEFAULT '0' COMMENT '操作类别0其它 1后台用户 2手机端用户', `operate_type` bigint(4) NOT NULL DEFAULT '0' COMMENT '操作分类',
`oper_name` varchar(50) DEFAULT '' COMMENT '操作人员', `content` varchar(2000) NOT NULL DEFAULT '' COMMENT '操作内容',
`dept_name` varchar(50) DEFAULT '' COMMENT '部门名称', `exts` varchar(512) NOT NULL DEFAULT '' COMMENT '拓展字段',
`oper_url` varchar(255) DEFAULT '' COMMENT '请求URL', `request_method` varchar(16) DEFAULT '' COMMENT '请求方法名',
`oper_ip` varchar(50) DEFAULT '' COMMENT '主机地址', `request_url` varchar(255) DEFAULT '' COMMENT '请求地址',
`oper_location` varchar(255) DEFAULT '' COMMENT '操作地点', `user_ip` varchar(50) DEFAULT NULL COMMENT '用户 IP',
`oper_param` varchar(2000) DEFAULT '' COMMENT '请求参数', `user_agent` varchar(50) DEFAULT NULL COMMENT '浏览器 UA',
`json_result` varchar(2000) DEFAULT '' COMMENT '返回参数', `java_method` varchar(512) NOT NULL DEFAULT '' COMMENT 'Java 方法名',
`status` int(1) DEFAULT '0' COMMENT '操作状态0正常 1异常', `java_method_args` varchar(8000) DEFAULT '' COMMENT 'Java 方法的参数',
`error_msg` varchar(2000) DEFAULT '' COMMENT '错误消息', `start_time` datetime NOT NULL COMMENT '操作时间',
`oper_time` datetime DEFAULT NULL COMMENT '操作时间', `duration` int(11) NOT NULL COMMENT '执行时长',
PRIMARY KEY (`oper_id`) `result_code` int(11) NOT NULL DEFAULT '0' COMMENT '结果码',
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='操作日志记录'; `result_msg` varchar(512) DEFAULT '' COMMENT '结果提示',
`result_data` varchar(4000) DEFAULT '' COMMENT '结果数据',
`create_by` varchar(64) DEFAULT '' COMMENT '创建者',
`create_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
`update_by` varchar(64) DEFAULT '' COMMENT '更新者',
`update_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
`deleted` bit(1) NOT NULL DEFAULT b'0' COMMENT '是否删除',
PRIMARY KEY (`id`) USING BTREE
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8mb4 COMMENT='操作日志记录';
-- ---------------------------- -- ----------------------------
-- Table structure for sys_post -- Table structure for sys_post
@ -367,7 +375,7 @@ CREATE TABLE `sys_user` (
`update_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间', `update_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
`deleted` bit(1) NOT NULL DEFAULT b'0' COMMENT '是否删除', `deleted` bit(1) NOT NULL DEFAULT b'0' COMMENT '是否删除',
PRIMARY KEY (`id`) USING BTREE PRIMARY KEY (`id`) USING BTREE
) ENGINE=InnoDB AUTO_INCREMENT=101 DEFAULT CHARSET=utf8mb4 COMMENT='用户信息表'; ) ENGINE=InnoDB AUTO_INCREMENT=104 DEFAULT CHARSET=utf8mb4 COMMENT='用户信息表';
-- ---------------------------- -- ----------------------------
-- Table structure for sys_user_role -- Table structure for sys_user_role

View File

@ -272,7 +272,7 @@ public class OperateLogAspect {
return ((MethodSignature) joinPoint.getSignature()).getMethod().getDeclaringClass().getAnnotation(annotationClass); return ((MethodSignature) joinPoint.getSignature()).getMethod().getDeclaringClass().getAnnotation(annotationClass);
} }
private static Map<String, Object> obtainMethodArgs(ProceedingJoinPoint joinPoint) { private static String obtainMethodArgs(ProceedingJoinPoint joinPoint) {
// TODO 提升:参数脱敏和忽略 // TODO 提升:参数脱敏和忽略
MethodSignature methodSignature = (MethodSignature) joinPoint.getSignature(); MethodSignature methodSignature = (MethodSignature) joinPoint.getSignature();
String[] argNames = methodSignature.getParameterNames(); String[] argNames = methodSignature.getParameterNames();
@ -285,7 +285,7 @@ public class OperateLogAspect {
// 被忽略时,标记为 ignore 字符串,避免和 null 混在一起 // 被忽略时,标记为 ignore 字符串,避免和 null 混在一起
args.put(argName, !isIgnoreArgs(argValue) ? argValue : "[ignore]"); args.put(argName, !isIgnoreArgs(argValue) ? argValue : "[ignore]");
} }
return args; return JSON.toJSONString(argValues);
} }
private static String obtainResultData(Object result) { private static String obtainResultData(Object result) {

View File

@ -0,0 +1,10 @@
/**
*
* 1. core
* 2. config Spring
*
*
* 1. MyBatisRedis
* 2.
*/
package cn.iocoder.dashboard.framework;

View File

@ -6,7 +6,6 @@ import lombok.Data;
import javax.validation.constraints.NotEmpty; import javax.validation.constraints.NotEmpty;
import javax.validation.constraints.NotNull; import javax.validation.constraints.NotNull;
import java.util.Date; import java.util.Date;
import java.util.Map;
/** /**
* Base VO VO 使 * Base VO VO 使
@ -56,7 +55,7 @@ public class SysOperateLogBaseVO {
private String javaMethod; private String javaMethod;
@ApiModelProperty(value = "Java 方法的参数") @ApiModelProperty(value = "Java 方法的参数")
private Map<String, Object> javaMethodArgs; private String javaMethodArgs;
@ApiModelProperty(value = "开始时间", required = true) @ApiModelProperty(value = "开始时间", required = true)
@NotNull(message = "开始时间不能为空") @NotNull(message = "开始时间不能为空")

View File

@ -24,6 +24,16 @@ import java.util.Map;
@EqualsAndHashCode(callSuper = true) @EqualsAndHashCode(callSuper = true)
public class SysOperateLogDO extends BaseDO { public class SysOperateLogDO extends BaseDO {
/**
* {@link #javaMethodArgs}
*/
public static final Integer JAVA_METHOD_ARGS_MAX_LENGTH = 8000;
/**
* {@link #resultData}
*/
public static final Integer RESULT_MAX_LENGTH = 4000;
/** /**
* *
*/ */
@ -54,6 +64,7 @@ public class SysOperateLogDO extends BaseDO {
* *
* {@link SysOperateLogTypeEnum} * {@link SysOperateLogTypeEnum}
*/ */
@TableField("operate_type")
private Integer type; private Integer type;
/** /**
* *
@ -94,9 +105,12 @@ public class SysOperateLogDO extends BaseDO {
private String javaMethod; private String javaMethod;
/** /**
* Java * Java
*
* Map<String, Object>
* 使 @TableField(typeHandler = FastjsonTypeHandler.class) JSON
* key value
*/ */
@TableField(typeHandler = FastjsonTypeHandler.class) private String javaMethodArgs;
private Map<String, Object> javaMethodArgs;
/** /**
* *
*/ */

View File

@ -5,12 +5,15 @@ import cn.iocoder.dashboard.modules.system.convert.logger.SysOperateLogConvert;
import cn.iocoder.dashboard.modules.system.dal.mysql.dao.logger.SysOperateLogMapper; import cn.iocoder.dashboard.modules.system.dal.mysql.dao.logger.SysOperateLogMapper;
import cn.iocoder.dashboard.modules.system.dal.mysql.dataobject.logger.SysOperateLogDO; import cn.iocoder.dashboard.modules.system.dal.mysql.dataobject.logger.SysOperateLogDO;
import cn.iocoder.dashboard.modules.system.service.logger.SysOperateLogService; import cn.iocoder.dashboard.modules.system.service.logger.SysOperateLogService;
import cn.iocoder.dashboard.util.string.StrUtils;
import lombok.extern.slf4j.Slf4j; import lombok.extern.slf4j.Slf4j;
import org.springframework.scheduling.annotation.Async; import org.springframework.scheduling.annotation.Async;
import org.springframework.stereotype.Service; import org.springframework.stereotype.Service;
import javax.annotation.Resource; import javax.annotation.Resource;
import static cn.iocoder.dashboard.modules.system.dal.mysql.dataobject.logger.SysOperateLogDO.*;
@Service @Service
@Slf4j @Slf4j
public class SysOperateLogServiceImpl implements SysOperateLogService { public class SysOperateLogServiceImpl implements SysOperateLogService {
@ -21,8 +24,10 @@ public class SysOperateLogServiceImpl implements SysOperateLogService {
@Override @Override
@Async @Async
public void createOperateLogAsync(SysOperateLogCreateReqVO reqVO) { public void createOperateLogAsync(SysOperateLogCreateReqVO reqVO) {
SysOperateLogDO logDO = SysOperateLogConvert.INSTANCE.convert(reqVO);
try { try {
SysOperateLogDO logDO = SysOperateLogConvert.INSTANCE.convert(reqVO);
logDO.setJavaMethodArgs(StrUtils.maxLength(logDO.getJavaMethodArgs(), JAVA_METHOD_ARGS_MAX_LENGTH));
logDO.setResultData(StrUtils.maxLength(logDO.getResultData(), RESULT_MAX_LENGTH));
operateLogMapper.insert(logDO); operateLogMapper.insert(logDO);
} catch (Throwable throwable) { } catch (Throwable throwable) {
// 仅仅打印日志,不对外抛出。原因是,还是要保留现场数据。 // 仅仅打印日志,不对外抛出。原因是,还是要保留现场数据。

View File

@ -0,0 +1,16 @@
package cn.iocoder.dashboard.util.string;
import cn.hutool.core.util.StrUtil;
/**
*
*
* @author
*/
public class StrUtils {
public static String maxLength(CharSequence str, int maxLength) {
return StrUtil.maxLength(str, maxLength - 3); // -3 的原因,是该方法会补充 ... 恰好
}
}