0

0

OpenAPI Generator Java 代码生成:精确控制字段命名大小写

DDD

DDD

发布时间:2025-11-22 14:04:47

|

603人浏览过

|

来源于php中文网

原创

openapi generator java 代码生成:精确控制字段命名大小写

在使用 OpenAPI Generator 生成 Java 代码时,默认情况下,工具可能会自动调整模型字段的命名大小写,例如将 `AIOBCategory` 转换为 `aiOBCategory`。本教程将详细介绍如何通过配置 `identifierNamingConvention` 选项,将其设置为 `original`,从而确保生成的 Java 字段名称完全保留 OpenAPI 规范中定义的原始大小写格式,以满足特定的命名约定需求。

了解 OpenAPI Generator 的默认命名行为

OpenAPI Generator 是一款强大的工具,能够根据 OpenAPI 规范(YAML 或 JSON)自动生成客户端、服务器存根和模型。然而,在生成 Java 等面向对象语言的代码时,它通常会遵循目标语言的惯例。例如,对于 Java 字段,标准的做法是使用小驼峰命名法(camelCase)。这意味着,如果您的 OpenAPI 规范中定义了一个字段名为 AIOBCategory:

AIOBCategory:
  type: string
  maxLength: 100
  example: ASD1234

在默认配置下,OpenAPI Generator 可能会将其转换为如下的 Java 字段:

@com.fasterxml.jackson.annotation.JsonProperty(JSON_PROPERTY_AI_O_B_CATEGORY)
private java.lang.String aiOBCategory;

这种转换虽然符合 Java 的一般命名规范,但在某些特定场景下,例如需要严格匹配数据库字段名、集成遗留系统或遵循特殊的 API 契约时,我们可能希望保留 OpenAPI 规范中定义的原始大小写。

立即学习Java免费学习笔记(深入)”;

精确控制字段命名:使用 identifierNamingConvention

OpenAPI Generator 提供了丰富的配置选项来定制生成过程,其中 identifierNamingConvention 就是用于控制标识符命名规则的关键选项。通过修改此选项,我们可以指定生成的字段、方法等标识符应遵循的命名约定。

要解决字段大小写被修改的问题,只需将 identifierNamingConvention 配置为 "original"。这将指示生成器完全保留 OpenAPI 规范中定义的原始字段名称,不做任何大小写转换。

Google AI Studio
Google AI Studio

Google 推出的基于浏览器的集成开发环境

下载

Gradle 插件配置示例

如果您正在使用 org.openapitools.generator.gradle.plugin 插件来集成 OpenAPI Generator,可以通过 openApiGenerate 任务的 configOptions 块来设置 identifierNamingConvention。

以下是一个具体的 Gradle 配置示例,演示如何确保生成的 Java 字段保持原始大小写:

plugins {
    id 'java'
    id 'org.openapi.generator' version '7.x.x' // 请替换为实际版本,例如 '7.5.0'
}

// ... 其他项目配置 ...

openApiGenerate {
    // 指定生成器名称,例如 "java" 或 "spring"
    generatorName = "java" 
    // OpenAPI 规范文件的路径
    inputSpec = "$rootDir/spec.yaml".toString() 
    // 生成代码的输出目录
    outputDir = "$buildDir/generated-src/openapi".toString() 
    // 配置选项
    configOptions = [
            // 关键配置:将标识符命名约定设置为 "original"
            identifierNamingConvention: "original" 
            // 您还可以添加其他配置,例如模型包名、API 包名等
            // modelPackage: "com.example.api.model",
            // apiPackage: "com.example.api.client"
    ]
    // 确保生成前清理旧代码
    clean = true 
}

// 将生成的代码添加到项目的源集
sourceSets {
    main {
        java {
            srcDir "$buildDir/generated-src/openapi/src/main/java"
        }
    }
}

// ... 其他任务或依赖 ...

在上述配置中,identifierNamingConvention: "original" 是核心。一旦应用此配置并运行 Gradle 构建,之前被转换为 aiOBCategory 的字段,现在将精确地生成为 AIOBCategory:

// 假设 OpenAPI 规范中定义为 AIOBCategory
@com.fasterxml.jackson.annotation.JsonProperty(JSON_PROPERTY_A_I_O_B_CATEGORY) 
private java.lang.String AIOBCategory;

注意事项:

  1. Jackson @JsonProperty 行为: 即使 Java 字段名通过 identifierNamingConvention: "original" 保持了原始大小写,@com.fasterxml.jackson.annotation.JsonProperty 注解中的值(如 JSON_PROPERTY_A_I_O_B_CATEGORY)可能仍然会遵循其内部的命名策略,将其转换为某种标准格式(如大写蛇形)。但这通常不影响 Java 字段本身的命名和 JSON 序列化/反序列化。
  2. 其他命名约定: identifierNamingConvention 除了 "original" 外,还支持其他值,例如 "snake_case"(蛇形命名)、"camelCase"(小驼峰命名,通常是默认值)、"PascalCase"(大驼峰命名)等。选择哪种约定取决于您的项目需求和团队规范。
  3. GeneratorName 的选择: 示例中使用了 java,但根据您的具体需求(如 Spring Boot 项目),您可能需要选择 spring、jaxrs-spec 等其他生成器。不同的生成器可能对某些配置项有特定的行为或默认值。
  4. 官方文档查阅: 强烈建议查阅 OpenAPI Generator 的官方配置文档(https://openapi-generator.tech/docs/configuration),以获取最全面和最新的配置选项信息,特别是针对您使用的特定生成器。

总结

通过在 OpenAPI Generator 配置中设置 identifierNamingConvention: "original",您可以有效地控制 Java 代码生成过程中字段的命名大小写,确保其与 OpenAPI 规范中的定义完全一致。这对于维护命名一致性、简化与现有系统集成以及遵循特定编码标准至关重要。在应用此配置时,请务必结合项目实际需求和目标语言的通用实践进行权衡。

相关专题

更多
java
java

Java是一个通用术语,用于表示Java软件及其组件,包括“Java运行时环境 (JRE)”、“Java虚拟机 (JVM)”以及“插件”。php中文网还为大家带了Java相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

831

2023.06.15

java正则表达式语法
java正则表达式语法

java正则表达式语法是一种模式匹配工具,它非常有用,可以在处理文本和字符串时快速地查找、替换、验证和提取特定的模式和数据。本专题提供java正则表达式语法的相关文章、下载和专题,供大家免费下载体验。

737

2023.07.05

java自学难吗
java自学难吗

Java自学并不难。Java语言相对于其他一些编程语言而言,有着较为简洁和易读的语法,本专题为大家提供java自学难吗相关的文章,大家可以免费体验。

733

2023.07.31

java配置jdk环境变量
java配置jdk环境变量

Java是一种广泛使用的高级编程语言,用于开发各种类型的应用程序。为了能够在计算机上正确运行和编译Java代码,需要正确配置Java Development Kit(JDK)环境变量。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

397

2023.08.01

java保留两位小数
java保留两位小数

Java是一种广泛应用于编程领域的高级编程语言。在Java中,保留两位小数是指在进行数值计算或输出时,限制小数部分只有两位有效数字,并将多余的位数进行四舍五入或截取。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

398

2023.08.02

java基本数据类型
java基本数据类型

java基本数据类型有:1、byte;2、short;3、int;4、long;5、float;6、double;7、char;8、boolean。本专题为大家提供java基本数据类型的相关的文章、下载、课程内容,供大家免费下载体验。

446

2023.08.02

java有什么用
java有什么用

java可以开发应用程序、移动应用、Web应用、企业级应用、嵌入式系统等方面。本专题为大家提供java有什么用的相关的文章、下载、课程内容,供大家免费下载体验。

430

2023.08.02

java在线网站
java在线网站

Java在线网站是指提供Java编程学习、实践和交流平台的网络服务。近年来,随着Java语言在软件开发领域的广泛应用,越来越多的人对Java编程感兴趣,并希望能够通过在线网站来学习和提高自己的Java编程技能。php中文网给大家带来了相关的视频、教程以及文章,欢迎大家前来学习阅读和下载。

16925

2023.08.03

Java 项目构建与依赖管理(Maven / Gradle)
Java 项目构建与依赖管理(Maven / Gradle)

本专题系统讲解 Java 项目构建与依赖管理的完整体系,重点覆盖 Maven 与 Gradle 的核心概念、项目生命周期、依赖冲突解决、多模块项目管理、构建加速与版本发布规范。通过真实项目结构示例,帮助学习者掌握 从零搭建、维护到发布 Java 工程的标准化流程,提升在实际团队开发中的工程能力与协作效率。

8

2026.01.12

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 2.4万人学习

C# 教程
C# 教程

共94课时 | 6.5万人学习

Java 教程
Java 教程

共578课时 | 45万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号