プロジェクトの統合システムログ

システムログ

springフレームワークを使用するaopと、ビジネスコードと、ロギング、トランザクション、その他のセキュリティサービスなどのシステムレベルのサービスの分離を実現できます。これにより、プロジェクトの保守が容易になり、エレガントになります。対応するログをシステムに追加するにはどうすればよいですか?

依存関係を追加する
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-aop</artifactId>
</dependency>
カスタムアノテーション
@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface SysLog {
    
    
    String value() default "";
}

構成の側面
@Aspect
@Component
public class SysLogAspect {
    
    
    @Autowired
    private SysLogService sysLogService;
    private static Logger logger = LoggerFactory.getLogger(SysLogAspect.class);

    @Around("@annotation(sysLog)")
    public Object around(ProceedingJoinPoint joinPoint,com.yami.shop.common.annotation.SysLog sysLog) throws Throwable {
    
    
        long beginTime = SystemClock.now();
        //执行方法
        Object result = joinPoint.proceed();
        //执行时长(毫秒)
        long time = SystemClock.now() - beginTime;

        SysLog sysLogEntity = new SysLog();
        if(sysLog != null){
    
    
            //注解上的描述
            sysLogEntity.setOperation(sysLog.value());
        }

        //请求的方法名
        String className = joinPoint.getTarget().getClass().getName();
        String methodName = joinPoint.getSignature().getName();
        sysLogEntity.setMethod(className + "." + methodName + "()");

        //请求的参数
        Object[] args = joinPoint.getArgs();
        String params = Json.toJsonString(args[0]);
        sysLogEntity.setParams(params);

        //设置IP地址
        sysLogEntity.setIp(IPHelper.getIpAddr());
        //用户名
        String username = SecurityUtils.getSysUser().getUsername();
        sysLogEntity.setUsername(username);
        sysLogEntity.setTime(time);
        sysLogEntity.setCreateDate(new Date());
        //保存系统日志
        sysLogService.save(sysLogEntity);
        return result;
    }

}

乗り、エントリーポイントとしてカスタムアノテーションをパラメータがあるProceedingJoinPointsysLogProceedingJoinPoint現在実行方法、取得するために使用されるsyslog注釈の値を取得するために使用します。

ログを記録する必要があるメソッドにコメントを追加します@SysLog(value)

@SysLog("修改角色")
@PutMapping
@PreAuthorize("@pms.hasPermission('sys:role:update')")
public ResponseEntity<Void> update(@RequestBody SysRole role){
    
    
    sysRoleService.updateRoleAndRoleMenu(role);
    return ResponseEntity.ok().build();
}

この方法を実行すると、データベースに記録され、対応する操作の内容がログ管理で確認できます。
img

おすすめ

転載: blog.csdn.net/lmsfv/article/details/106068588