疯狂的狮子li
2021-09-02 8b2f7f0e647dca1716a0f792dabb7756c822a9ec
ruoyi-framework/src/main/java/com/ruoyi/framework/mybatisplus/CreateAndUpdateMetaObjectHandler.java
@@ -1,10 +1,9 @@
package com.ruoyi.framework.mybatisplus;
import cn.hutool.core.lang.Validator;
import cn.hutool.http.HttpStatus;
import com.baomidou.mybatisplus.core.handlers.MetaObjectHandler;
import com.ruoyi.common.core.domain.model.LoginUser;
import com.ruoyi.common.exception.CustomException;
import com.ruoyi.common.exception.ServiceException;
import com.ruoyi.common.utils.SecurityUtils;
import lombok.extern.slf4j.Slf4j;
import org.apache.ibatis.reflection.MetaObject;
@@ -25,35 +24,28 @@
      try {
         //根据属性名字设置要填充的值
         if (metaObject.hasGetter("createTime")) {
            if (Validator.isEmpty(metaObject.getValue("createTime"))) {
               this.setFieldValByName("createTime", new Date(), metaObject);
            }
            this.setFieldValByName("createTime", new Date(), metaObject);
         }
         if (metaObject.hasGetter("createBy")) {
            if (Validator.isEmpty(metaObject.getValue("createBy"))) {
               this.setFieldValByName("createBy", getLoginUsername(), metaObject);
            }
            this.setFieldValByName("createBy", getLoginUsername(), metaObject);
         }
      } catch (Exception e) {
         throw new CustomException("自动注入异常 => " + e.getMessage(), HttpStatus.HTTP_UNAUTHORIZED);
         throw new ServiceException("自动注入异常 => " + e.getMessage(), HttpStatus.HTTP_UNAUTHORIZED);
      }
      updateFill(metaObject);
   }
   @Override
   public void updateFill(MetaObject metaObject) {
      try {
         if (metaObject.hasGetter("updateBy")) {
            if (Validator.isEmpty(metaObject.getValue("updateBy"))) {
               this.setFieldValByName("updateBy", getLoginUsername(), metaObject);
            }
            this.setFieldValByName("updateBy", getLoginUsername(), metaObject);
         }
         if (metaObject.hasGetter("updateTime")) {
            if (Validator.isEmpty(metaObject.getValue("updateTime"))) {
               this.setFieldValByName("updateTime", new Date(), metaObject);
            }
            this.setFieldValByName("updateTime", new Date(), metaObject);
         }
      } catch (Exception e) {
         throw new CustomException("自动注入异常 => " + e.getMessage(), HttpStatus.HTTP_UNAUTHORIZED);
         throw new ServiceException("自动注入异常 => " + e.getMessage(), HttpStatus.HTTP_UNAUTHORIZED);
      }
   }
@@ -65,7 +57,7 @@
      try {
         loginUser = SecurityUtils.getLoginUser();
      } catch (Exception e) {
         log.warn("自动注入警告 => 用户未登录");
         log.error("自动注入警告 => 用户未登录");
         return null;
      }
      return loginUser.getUsername();