【springboot】从解决@valid失效问题 到根据判断放行的更灵活替代方案 再到优雅的打日志
创始人
2024-05-02 21:39:25
0

文章目录

  • 前言
  • @valid失效问题
  • 替代方案

前言

@valid 可以帮助我们节省很多代码 比较方便 但操作失误时 可能会失效 达不到我们预期效果;

@valid会有个问题 因为注解过于方便 反而会导致拦截后 错误日志的收集会比较麻烦 ,以及在面对有时需要拦截 有时不需要拦截的特定场景下 显得无计可施 此时我们还是要回归手写校验

本文将从解决@valid失效问题 及提供更灵活的方案两个方面进行简述

@valid失效问题

  1. 检查依赖 单独引入validation-api可能无效 我们看看springboot给出的提示
    在这里插入图片描述
		org.springframework.bootspring-boot-starter-validation
  1. 检查是否使用错误

需要校验的类添加@Validated注解(有接口的情况下 可加在接口 也可在实现类 推荐统一加在接口)

方法参数需要添加@Valid注解 (有接口的情况下 需要加在接口的方法参数)

实体类参数需要添加校验注解 如@NotNull 下面用代码举个例子

// 注意是 interface 
@Validated
public interface DeviceConfigService extends IService {void putDeviceConfigList(@Valid DeviceConfigUpdaterCmd cmd);
}
@Data
@EqualsAndHashCode
public class DeviceConfigUpdaterCmd implements Serializable {private static final long serialVersionUID=1L;@NotNull(message = "错误")private Long id;}

替代方案

举个例子 我们项目和外部的接口进行对接 鉴于主动防御原则 我们可能对其某些参数进行校验,当id参数为空时 我们需要写入日志 方便快速定位(甩锅)问题

传统的写法是

if (null != cmd.getId){throw new RuntimeException("参数不能为空");
}

你是否也感觉一片的 if 看着很让人恼火 又无计可施呢?
再后来 可能我们会从spring源码中的断言类受到启发,用spring的姿势是这么去判断的

Assert.notNull(id,"不能为空");
	// spring的 Assert 类public static void notNull(@Nullable Object object, String message) {if (object == null) {throw new IllegalArgumentException(message);}}

但这随之而来有个很大的问题 ,我们如何打日志呢?

这个时候我们应该想到 jdk8开始 提供了函数式接口,我们可以直接将方法传入

比如Function Consumer 都可以做到,但是关键在于方法传入 如何让它执行呢?

所以我们选择了Consumer消费型函数,看完下面代码 我们就能很好的理解为什么它叫消费型函数了:
在这里插入图片描述

如果对Consumer不熟悉的同学 或许会感到疑惑 网上似乎都是此类教程,这到底有什么用?接着往下看 我们用函数式简化一下

在这里插入图片描述

我们能看出来,我们test()方法的参数 也是一个方法,并且accept会将该方法执行(消费),
且accept(T t)是必须要有参数的 ,

在这里插入图片描述

然而 我们写日志的时候 log.error(“msg”) ,这一步骤就够了 我们并不需要额外将 "msg” 交给accpet来处理,
那应该怎么办呢?

于是我们可以参数给定一个空串 :

	// 自定义一个CommonAssert类public static void notNull(@Nullable Object object, String msg, Consumer consumer) {if (null == object) {// 消费该方法 (执行该方法)consumer.accept("");throw new RuntimeException(msg);}}

使用方代码:

        CommonAssert.notNull(id, "id error", item -> log.error("id error"));

相关内容

热门资讯

【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
AsusVivobook无法开... 首先,我们可以尝试重置BIOS(Basic Input/Output System)来解决这个问题。...
月入8000+的steam搬砖... 大家好,我是阿阳 今天要给大家介绍的是 steam 游戏搬砖项目,目前...
​ToDesk 远程工具安装及... 目录 前言 ToDesk 优势 ToDesk 下载安装 ToDesk 功能展示 文件传输 设备链接 ...