Api 设计,你的max/min 长度、元素数与属性数用对了吗?

Api 设计,你的max/min 长度、元素数与属性数用对了吗?

学习如何正确使用这些验证关键字,以及 ApiHug 是如何根据标准进行设计的。

本文将详细介绍 max/min lengthitemsproperties 这些关键字之间的区别,并解释它们与 minimummaximum 的关系。

这些关键字通常用于定义以下数据类型时:

  1. 基本类型(如 number、string)
  2. 数组类型
  3. 字典、哈希表以及其他对象类型

​官方定义

​minimum 与 maximum

使用 minimummaximum 来指定数值类型的取值范围:

vbnet 复制代码
type: integer
minimum: 1
maximum: 20

默认情况下,边界值是 包含在内的

复制代码
minimum ≤ value ≤ maximum

如果希望排除某个边界值,请设置 exclusiveMinimumexclusiveMaximumtrue。例如,定义一个浮点数必须大于 0 且小于等于 50:

vbnet 复制代码
type: number
minimum: 0
exclusiveMinimum: true
maximum: 50
关键字 描述
exclusiveMinimum: false 或未设置 value ≥ minimum
exclusiveMinimum: true value > minimum
exclusiveMaximum: false 或未设置 value ≤ maximum
exclusiveMaximum: true value < maximum

​minLength 与 maxLength

使用 minLengthmaxLength 来限制字符串的长度:

vbnet 复制代码
type: string
minLength: 3
maxLength: 20

​minItems 与 maxItems

对于数组类型,可以使用 minItemsmaxItems 来指定允许的最小和最大元素个数:

vbnet 复制代码
type: array
items:
  type: integer
minItems: 1
maxItems: 10

​minProperties 与 maxProperties

使用 minPropertiesmaxProperties 可以限制对象中允许的属性数量。这对于动态对象(如字典、HashMap)非常有用:

vbnet 复制代码
type: object
minProperties: 2
maxProperties: 10

​ApiHug 实现方式

ApiHug 严格遵循 Swagger 3.0+ 规范,在生成 API 文档和代码时都按照该规范进行设计。

​示例 1:数组验证

Protobuf 定义:

yaml 复制代码
repeated string all_names = 2 [(hope.swagger.field) = {
        description: "所有名字列表";
        example: "user"
        blank: FALSE;
        max_length: {
            value: 64
        }
        max_items:{
            value: 22
        }
        min_items: {
            value: 11
        }
    }];

生成的 Java 代码:

less 复制代码
@Size(
      min = 11,
      max = 22
  )
  @ArraySchema(
      minItems = 11,
      maxItems = 22,
      schema = @Schema(description = "所有名字列表", 
                       maxLength = 64, 
                       requiredMode = Schema.RequiredMode.REQUIRED, 
                       example = "user", extensions = @Extension(name = "x-hope-validation", properties = @ExtensionProperty(name = "blank", value = "false")), implementation = String.class)
  )
  protected List<@NotBlank @Size(max = 64) String> allNames;

​示例 2:对象属性限制

Protobuf 定义:

ini 复制代码
map<string, Pet> all_pets = 3 [(hope.swagger.field) = {
        description: "我所有的宠物";

        max_properties:{
            value: 22
        }
        min_properties: {
            value: 11
        }
    }];

生成的 Java 代码:

less 复制代码
@Size(
      min = 11,
      max = 22
  )
  @Schema(
      description = "我所有的宠物",
      maxProperties = 22,
      minProperties = 11
  )
  protected Map<String, Pet> allPets;
  1. 在 API 定义中应避免使用复杂的数据结构,以保持接口的清晰性和兼容性。
  2. 在 API 的 Map 定义中,建议仅使用字符串作为键,以确保跨系统和语言的一致性与稳定性。

​参考资料

  1. Swagger V3 - 数据类型
  2. Swagger V3 - 字典、哈希表与关联数组
相关推荐
胖咕噜的稞达鸭36 分钟前
自定义shell命令行解释器自制
java·开发语言
q***33374 小时前
oracle 12c查看执行过的sql及当前正在执行的sql
java·sql·oracle
Y***h1877 小时前
第二章 Spring中的Bean
java·后端·spring
8***29317 小时前
解决 Tomcat 跨域问题 - Tomcat 配置静态文件和 Java Web 服务(Spring MVC Springboot)同时允许跨域
java·前端·spring
CoderYanger7 小时前
优选算法-栈:67.基本计算器Ⅱ
java·开发语言·算法·leetcode·职场和发展·1024程序员节
q***06298 小时前
Tomcat的升级
java·tomcat
多多*8 小时前
Java复习 操作系统原理 计算机网络相关 2025年11月23日
java·开发语言·网络·算法·spring·microsoft·maven
青云交8 小时前
Java 大视界 -- Java 大数据在智能物流无人配送车路径规划与协同调度中的应用
java·spark·路径规划·大数据分析·智能物流·无人配送车·协同调度
d***81728 小时前
解决SpringBoot项目启动错误:找不到或无法加载主类
java·spring boot·后端
ᐇ9598 小时前
Java集合框架深度实战:构建智能教育管理与娱乐系统
java·开发语言·娱乐