搜索
首页Javajava教程SpringBoot Web服务-部分初始配置

SpringBoot Web Service - Part  Initial Configuration

在这篇文章中,我们将探索如何在 Spring Boot 应用程序中配置 OpenAPI,并添加从根 URL 到 Swagger UI 的便捷重定向。此设置将改进您的 API 文档并使其更易于开发人员访问。

OpenAPI Bean 配置

首先,让我们创建一个配置类来自定义我们的 OpenAPI 文档:

import io.swagger.v3.oas.models.OpenAPI;
import io.swagger.v3.oas.models.info.Contact;
import io.swagger.v3.oas.models.info.Info;
import io.swagger.v3.oas.models.info.License;
import org.springframework.boot.info.GitProperties;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

@Configuration
public class OpenAPIConfig {

    @Bean
    public OpenAPI customOpenAPI(GitProperties gitProperties) {
        return new OpenAPI()
                .info(new Info()
                        .title("Book Catalog API")
                        .description("REST API for managing a book catalog. Application version: "+ gitProperties.get("build.version"))
                        .version("1.0.0")
                        .contact(new Contact()
                                .name("Book Catalog Team")
                                .email("support@bookcatalog.com")
                                .url("https://github.com/vlaship/book-catalog"))
                        .license(new License()
                                .name("MIT License")
                                .url("https://opensource.org/licenses/MIT"))
                );
    }
}

此配置创建一个自定义 OpenAPI bean,其中包含有关您的 API 的基本信息。您可以通过添加更多详细信息(例如联系信息、许可证或外部文档)来进一步自定义。
我们可以使用 GitProperties 来提供更多详细信息。

根 URL 重定向控制器

接下来,让我们创建一个控制器来将用户从根 URL 重定向到 Swagger UI:

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;

@Controller
public class OpenApiController {
    @GetMapping("/")
    public String index() {
        return "redirect:swagger-ui.html";
    }
}

这个简单的控制器使用 @GetMapping 作为根 URL(“/”)并重定向到 Swagger UI HTML 页面。

更新 application.yaml

此配置文件通常名为 application.yml,在定义应用程序行为的各个方面起着至关重要的作用。

spring:
  application:
    name: book-catalog
    version: '@project.version@'
  mvc:
    problemdetails:
      enabled: true

management:
  endpoints:
    web:
      exposure:
        include: '*'
  info:
    git:
      mode: full

server:
  port: 8888
  servlet:
    context-path: /${spring.application.name}
  error:
    whitelabel:
      enabled: false

提供的 YAML 配置涵盖了 Spring Boot 应用程序的几个关键领域:

  1. 应用程序属性:

name:定义应用程序的名称,这里设置为 book-catalog。

版本:引用可能在构建过程中填充的占位符,以指定应用程序的版本。

  1. MVC 配置:

problemdetails.enabled:在异常响应正文中启用详细问题报告。

  1. 管理端点:

endpoints.web.exposure.include: '*':** 公开所有执行器端点以用于监视和管理目的。

info.git.mode: full:在 /info 端点中提供详细的 Git 信息。

  1. 服务器配置:

port:设置服务器监听传入请求的端口(默认8080,这里设置为8888)。

servlet.context-path:定义应用程序的上下文路径,确保请求正确路由。

error.whitelabel.enabled: false:禁用默认的白标签错误页面,以便在开发过程中提供更多信息性错误消息。

添加banner.txt

1。创建banner.txt文件

在 Spring Boot 项目的 src/main/resources 目录中创建一个名为 Banner.txt 的新文件。

2。将服务详细信息添加到banner.txt

您可以将任何文本或 ASCII 艺术添加到此文件中。这是一个例子:

import io.swagger.v3.oas.models.OpenAPI;
import io.swagger.v3.oas.models.info.Contact;
import io.swagger.v3.oas.models.info.Info;
import io.swagger.v3.oas.models.info.License;
import org.springframework.boot.info.GitProperties;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

@Configuration
public class OpenAPIConfig {

    @Bean
    public OpenAPI customOpenAPI(GitProperties gitProperties) {
        return new OpenAPI()
                .info(new Info()
                        .title("Book Catalog API")
                        .description("REST API for managing a book catalog. Application version: "+ gitProperties.get("build.version"))
                        .version("1.0.0")
                        .contact(new Contact()
                                .name("Book Catalog Team")
                                .email("support@bookcatalog.com")
                                .url("https://github.com/vlaship/book-catalog"))
                        .license(new License()
                                .name("MIT License")
                                .url("https://opensource.org/licenses/MIT"))
                );
    }
}

这种方法为您的应用程序启动增添了专业感,并一目了然地提供有价值的信息。

添加 Dockerfile

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;

@Controller
public class OpenApiController {
    @GetMapping("/")
    public String index() {
        return "redirect:swagger-ui.html";
    }
}

图层提取:为依赖项创建单独的图层,提高构建效率并减少图像大小更新。
多阶段构建:利用多阶段构建过程将构建环境与运行时环境分开,从而产生更小、更高效的最终图像。
轻量级基础镜像: 使用像 azul/zulu-openjdk-alpine:21-jre-headless 这样的最小基础镜像来进一步减小镜像大小。

这种方法可以加快 Docker 容器内 Spring Boot 应用程序的构建速度、缩小镜像大小并提高整体性能。

以上是SpringBoot Web服务-部分初始配置的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
如何在Java中解析next-auth生成的JWT token并获取其中的信息?如何在Java中解析next-auth生成的JWT token并获取其中的信息?Apr 19, 2025 pm 08:21 PM

在处理next-auth生成的JWT...

为什么JavaScript无法直接获取用户电脑的硬件信息?为什么JavaScript无法直接获取用户电脑的硬件信息?Apr 19, 2025 pm 08:15 PM

关于JavaScript无法获取用户电脑硬件信息的原因探讨在日常编程中,许多开发者会好奇为什么JavaScript无法直接获�...

RuoYi框架中出现循环依赖,如何排查并解决dynamicDataSource Bean的问题?RuoYi框架中出现循环依赖,如何排查并解决dynamicDataSource Bean的问题?Apr 19, 2025 pm 08:12 PM

RuoYi框架循环依赖问题排查与解决在使用RuoYi框架进行开发时,常常会遇到循环依赖的问题,这往往会导致程序�...

在使用Spring Cloud Alibaba搭建微服务架构时,是否必须将各个模块放在一个父子工程结构中进行管理?在使用Spring Cloud Alibaba搭建微服务架构时,是否必须将各个模块放在一个父子工程结构中进行管理?Apr 19, 2025 pm 08:09 PM

关于SpringCloudAlibaba微服务的模块化开发在使用SpringCloud...

曲线积分中x²的处理:标准答案为何能忽略(1/3)x³?曲线积分中x²的处理:标准答案为何能忽略(1/3)x³?Apr 19, 2025 pm 08:06 PM

关于一道曲线积分的疑惑这篇文章将针对一道曲线积分问题进行解答。提问者对一道例题的标准答案产生了疑问...

Spring Boot中OAuth2Authorization对象Redis缓存失败怎么办?Spring Boot中OAuth2Authorization对象Redis缓存失败怎么办?Apr 19, 2025 pm 08:03 PM

SpringBoot中使用Redis缓存OAuth2Authorization对象在SpringBoot应用中,使用SpringSecurityOAuth2AuthorizationServer...

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

Dreamweaver Mac版

Dreamweaver Mac版

视觉化网页开发工具

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

功能强大的PHP集成开发环境

SecLists

SecLists

SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)