审计日志相关代码提交

This commit is contained in:
2022-07-12 16:10:50 +08:00
parent 79b6ade43a
commit d00bd4bf0c
9 changed files with 286 additions and 6 deletions

View File

@@ -0,0 +1,25 @@
package com.njcn.system.api;
import com.njcn.common.pojo.constant.ServerInfo;
import com.njcn.common.pojo.dto.LogInfoDTO;
import com.njcn.system.api.fallback.UserLogFeignClientFallbackFactory;
import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;
/**
* @author hongawen
* @version 1.0.0
* @date 2022年07月12日 15:20
*/
@FeignClient(value = ServerInfo.SYSTEM,path = "/userLog",fallbackFactory = UserLogFeignClientFallbackFactory.class)
public interface UserLogFeignClient {
/**
* 插入审计日志
* @param logInfoDTO 日志详细信息
*/
@PostMapping("/add")
void addUserLog(@RequestBody LogInfoDTO logInfoDTO);
}

View File

@@ -0,0 +1,48 @@
package com.njcn.system.api.fallback;
import com.njcn.common.pojo.dto.LogInfoDTO;
import com.njcn.common.pojo.enums.response.CommonResponseEnum;
import com.njcn.common.pojo.exception.BusinessException;
import com.njcn.common.pojo.response.HttpResult;
import com.njcn.system.api.AreaFeignClient;
import com.njcn.system.api.UserLogFeignClient;
import com.njcn.system.pojo.dto.AreaTreeDTO;
import com.njcn.system.pojo.po.Area;
import com.njcn.system.utils.SystemEnumUtil;
import lombok.extern.slf4j.Slf4j;
import org.springframework.stereotype.Component;
import feign.hystrix.FallbackFactory;
/**
* @author hongawen
* @version 1.0.0
* @date 2022年07月12日 15:21
*/
@Slf4j
@Component
public class UserLogFeignClientFallbackFactory implements FallbackFactory<UserLogFeignClient> {
/**
* 输出远程请求接口异常日志
* @param cause RPC请求异常
*/
@Override
public UserLogFeignClient create(Throwable cause) {
//判断抛出异常是否为解码器抛出的业务异常
Enum<?> exceptionEnum = CommonResponseEnum.SERVICE_FALLBACK;
if(cause.getCause() instanceof BusinessException){
BusinessException businessException = (BusinessException) cause.getCause();
exceptionEnum = SystemEnumUtil.getExceptionEnum(businessException.getResult());
}
Enum<?> finalExceptionEnum = exceptionEnum;
return new UserLogFeignClient() {
@Override
public void addUserLog(LogInfoDTO logInfoDTO) {
log.error("{}异常,降级处理,异常为:{}","插入审计日志",cause.toString());
throw new BusinessException(finalExceptionEnum);
}
};
}
}