From ad1be7289d5e0858b49951efaa7088e3a656c82b Mon Sep 17 00:00:00 2001
From: yaowanxin <3588231647@qq.com>
Date: 星期一, 25 八月 2025 18:00:58 +0800
Subject: [PATCH] 人力资源模块
---
ruoyi-common/src/main/java/com/ruoyi/common/handler/MyMetaObjectHandler.java | 68 ++++++++++++++++++++-------------
1 files changed, 41 insertions(+), 27 deletions(-)
diff --git a/ruoyi-common/src/main/java/com/ruoyi/common/handler/MyMetaObjectHandler.java b/ruoyi-common/src/main/java/com/ruoyi/common/handler/MyMetaObjectHandler.java
index 81c6558..da15fc7 100644
--- a/ruoyi-common/src/main/java/com/ruoyi/common/handler/MyMetaObjectHandler.java
+++ b/ruoyi-common/src/main/java/com/ruoyi/common/handler/MyMetaObjectHandler.java
@@ -5,44 +5,58 @@
import org.apache.ibatis.reflection.MetaObject;
import org.springframework.stereotype.Component;
-import java.time.OffsetDateTime;
+import java.time.LocalDateTime;
@Component
public class MyMetaObjectHandler implements MetaObjectHandler {
+ private static final String SYSTEM_USER = "system";
+
@Override
- public void insertFill(MetaObject metaObject) {
- // 鍒ゆ柇瀛楁鏄惁瀛樺湪锛屽瓨鍦ㄦ墠濉厖
- if (metaObject.hasSetter("createBy")) {
- Long userId;
- try {
- if (SecurityUtils.getLoginUser() != null) {
- userId = SecurityUtils.getLoginUser().getUserId();
- this.strictInsertFill(metaObject, "createBy", String.class, userId.toString());
- }
- } catch (Exception ignored) {
- }
- }
+ public void insertFill(MetaObject meta) {
+ LocalDateTime now = LocalDateTime.now();
+ String userId = getUserId();
- if (metaObject.hasSetter("createTime")) {
- this.strictInsertFill(metaObject, "createTime", OffsetDateTime.class, OffsetDateTime.now());
+ if (hasField(meta, "createBy")) {
+ strictInsertFill(meta, "createBy", String.class, userId);
}
-
- if (metaObject.hasSetter("updateTime")) {
- this.strictUpdateFill(metaObject, "updateTime", OffsetDateTime.class, OffsetDateTime.now());
- }
+ if (hasField(meta, "updateBy")) {
+ strictInsertFill(meta, "updateBy", String.class, userId);
+ }
+ if (hasField(meta, "createTime")) {
+ strictInsertFill(meta, "createTime", LocalDateTime.class, now);
+ }
+ if (hasField(meta, "updateTime")) {
+ strictInsertFill(meta, "updateTime", LocalDateTime.class, now);
+ }
}
@Override
- public void updateFill(MetaObject metaObject) {
- // 鍒ゆ柇瀛楁鏄惁瀛樺湪锛屽瓨鍦ㄦ墠濉厖
- if (metaObject.hasSetter("updateBy")) {
- Long userId = SecurityUtils.getLoginUser().getUserId();
- this.strictUpdateFill(metaObject, "updateBy", String.class, userId.toString());
- }
+ public void updateFill(MetaObject meta) {
+ LocalDateTime now = LocalDateTime.now();
+ String userId = getUserId();
- if (metaObject.hasSetter("updateTime")) {
- this.strictUpdateFill(metaObject, "updateTime", OffsetDateTime.class, OffsetDateTime.now());
+ if (hasField(meta, "updateBy")) {
+ strictUpdateFill(meta, "updateBy", String.class, userId);
}
+ if (hasField(meta, "updateTime")) {
+ setFieldValByName("updateTime", now, meta);
+ }
+ }
+
+ private String getUserId() {
+ try {
+ Long uid = SecurityUtils.getLoginUser().getUserId();
+ return uid != null ? uid.toString() : SYSTEM_USER;
+ } catch (Exception e) {
+ return SYSTEM_USER;
+ }
+ }
+
+ private boolean hasField(MetaObject meta, String fieldName) {
+ if (meta == null || fieldName == null) {
+ return false;
+ }
+ return meta.hasGetter(fieldName) || meta.hasSetter(fieldName);
}
}
\ No newline at end of file
--
Gitblit v1.9.3