SpringBoot之如何集成SpringDoc最详细文档
文章目录
- 一、概念解释
- 1、OpenAPI
- 2、Swagger
- 3、Springfox
- 4、Springdoc
- 5. 关系与区别
- 二、SpringDoc基本使用
- 1、导包
- 2、正常编写代码,不需要任何注解
- 3、运行后访问下面的链接即可
- 三、SpringDoc进阶使用
- 1、配置文档信息
- 2、配置文档分组
- 3、springdoc的配置参数
- **1. 基础配置**
- **API 文档路径-springdoc.api-docs.path**
- **Swagger UI 路径-springdoc.swagger-ui.path**
- **是否启用 API 文档-springdoc.api-docs.enabled**
- **是否启用 Swagger UI-springdoc.swagger-ui.enabled**
- **2. 全局元信息-info**
- **应用标题-springdoc.info.title**
- **应用描述-springdoc.info.description**
- **版本号-pringdoc.info.version**
- **联系人信息-springdoc.info.contact**
- **许可信息-pringdoc.info.license**
- **3. 分组与模块化**
- **分组支持-springdoc.group-configs**
- **扫描包范围-springdoc.packages-to-scan**
- **排除特定路径-springdoc.paths-to-exclude**
- **4. 安全配置**
- **全局安全方案**
- **全局安全要求**
- **5. 自定义行为**
- **缓存控制**
- **排序规则**
- **服务器地址-pringdoc.servers**
- **6. 高级配置**
- **自定义 OpenAPI 对象**
- **自定义 Swagger UI**
- **7. 总结**
- 4、SpringDoc注解
- **1. 核心注解**
- **@Tag**
- **2. 方法级别注解**
- **@Operation**
- **@ApiResponse 和 @ApiResponses**
- **3. 参数相关注解**
- **@Parameter**
- **@Parameters**
- **4. 实体模型相关注解**
- **@Schema**
- **5. 其他注解**
- **@Hidden**
- **6. 配置相关注解(不常用)**
- **@OpenAPIDefinition**
- **7. 总结**
- 四、在实际项目上如何使用
- 1、导包
- 2、写配置类
- 1)、配置实体类
- 2)、配置类
- 3、编写配置参数
系列文章:
springboot-swagger详解
springboot-优美的Knife4j文档-Swagger进化
Spring Cloud Gateway 网关整合 Knife4j
SpringBoot之如何集成SpringDoc最详细文档
一、概念解释
Swagger和Springdoc是两个常用的工具,用于生成和维护API文档,特别是针对基于REST的Web服务。它们有效地提升了API的可读性和可维护性,帮助开发者、产品经理和其他利益相关者更好地理解和使用所提供的API。
谈到API文档,那就绕不开大名鼎鼎的Swagger,但是你是否还听说过:OpenAPI,Springfox,Springdoc?你第一次看到这些脑瓜子是不是嗡嗡的?
1、OpenAPI
OpenApi 就像 JDBC 一样,制定了各种各样的规范,而 Swagger 和 SpringDoc 则类似于各种各样的数据库驱动,是具体的实现
-
定义 :OpenAPI 是一个开放标准,用于描述 RESTful API 的接口规范。它最初由 Swagger 项目发展而来,后来成为独立的标准(目前由 OpenAPI Initiative 维护)。
-
版本 :
- OpenAPI 2.0 :基于 Swagger 2.0 规范。
- OpenAPI 3.0+ :是更新的版本,引入了许多新特性(如增强的请求体描述、组件复用等)。
-
作用 :提供一种标准化的方式来描述 API 的结构、路径、参数、响应等内容,便于开发者和工具生成文档、测试接口。
2、Swagger
它是SmartBear这个公司的一个开源项目,里面提供了一系列工具,包括著名的 swagger-ui。
swagger是早于OpenApi的,某一天swagger将自己的API设计贡献给了OpenApi,然后由其标准化了。
- 定义 :Swagger 是一组围绕 OpenAPI 标准构建的工具集,包括代码生成器、UI 展示工具等。
- 版本 :
- Swagger 2.x :基于 OpenAPI 2.0,是最广泛使用的版本之一。
- Swagger 3.x :基于 OpenAPI 3.0+,支持更复杂的 API 描述功能。
- 工具 :
- Swagger UI :为 OpenAPI 文档提供交互式界面,方便开发者测试 API。
- Swagger Codegen :根据 OpenAPI 文档生成客户端代码或服务器端框架代码。
3、Springfox
是Spring生态的一个开源库,是Swagger与OpenApi规范的具体实现。我们使用它就可以在spring中生成API文档。以前基本上是行业标准,目前最新版本可以支持 Swagger2, Swagger3 以及 OpenAPI3 三种格式。但是其从 2020年7月14号就不再更新了,不支持springboot3,所以业界都在不断的转向我们今天要谈论的另一个库Springdoc,新项目就不要用了。
- 定义 :Springfox 是一个专门为 Spring 框架设计的库,用于自动生成基于 Swagger/OpenAPI 的 API 文档。
- 特点 :
- 支持 Spring MVC 和 Spring Boot。
- 主要基于 Swagger 2.x 和 OpenAPI 2.0 。
- 通过注解(如 @Api、@ApiOperation 等)来描述 API。
- 局限性 :
- 对 OpenAPI 3.0 的支持较弱(尽管有实验性支持,但不够完善)。
- 在 Spring Boot 2.6 及更高版本中,由于兼容性问题(如路径匹配策略的变化),Springfox 的使用变得复杂甚至不可行。
4、Springdoc
算是后起之秀,带着继任Springfox的使命而来。其支持OpenApi规范,支持Springboot3,我们的新项目都应该使用这个。
- 定义 :Springdoc 是一个现代化的开源库,专为 Spring Boot 应用程序设计,用于自动生成基于 OpenAPI 3.0+ 的 API 文档。
- 特点 :
- 原生支持 OpenAPI 3.0+ ,并提供对 Spring Boot 2.6+ 的良好兼容性。
- 使用标准的 OpenAPI 注解(如 @Operation、@Parameter 等),而不是 Swagger 特有的注解。
- 提供内置的 Swagger UI,方便开发者快速查看和测试 API。
- 优势 :
- 更轻量、更易配置。
- 更好的性能和兼容性。
- 社区活跃,更新频繁。
SpringDoc 支持:
- OpenAPI 3
- Spring-boot,全版本都支持。
- JSR-303 中提供的一些注解,例如 @NotNull、@Min、@Max 以及 @Size 等。
- Swagger-ui:SpringDoc 提供的接口 JSON 也可以通过 Swagger-ui 展示出来。
- OAuth 2
- …
5. 关系与区别
| 特性 | Springfox | Springdoc | Swagger | OpenAPI |
|---|---|---|---|---|
| 主要用途 | 自动生成 API 文档 | 自动生成 API 文档 | 工具集,用于生成文档和测试 API | API 描述标准 |
| 支持的规范 | Swagger 2.x / OpenAPI 2.0 | OpenAPI 3.0+ | Swagger 2.x / Swagger 3.x | OpenAPI 2.0 / OpenAPI 3.0+ |
| Spring Boot 兼容性 | 较差(尤其是 2.6+ 版本) | 良好 | 不直接相关 | 不直接相关 |
| 注解 | 使用 Swagger 特定注解(如 @Api) | 使用 OpenAPI 标准注解(如 @Operation) | 使用 Swagger 特定注解 | 定义了标准注解 |
| 工具支持 | 提供 Swagger UI | 提供 Swagger UI | 提供 Swagger UI 和 Codegen | 无直接工具支持,需依赖实现(如 Swagger) |
| 社区活跃度 | 逐渐减少 | 高 | 高 | 高 |
二、SpringDoc基本使用
我们可以在springboot中使用SpringDoc来生成API文档,详情可以参考官网,下面我们来简单的实践一下。
1、导包
在springboot中使用springdoc起步非常容易,只需要引入其starter即可
<dependency><groupId>org.springdoc</groupId><artifactId>springdoc-openapi-ui</artifactId><version>1.7.0</version> <!-- 版本可替换 -->
</dependency>
2、正常编写代码,不需要任何注解

3、运行后访问下面的链接即可
http://server:port/context-path/swagger-ui.html
例如:
http://localhost:9204/swagger-ui.html

三、SpringDoc进阶使用
虽然上边配置的SpringDoc很好用,但是对比swagger我们就知道,缺少了很多信息,当然springdoc的集成不可能就这点东西,不然也没有这篇文章了。
1、配置文档信息
得益于springboot的强大,我们只需添加一个依赖就可以使用API文档了,但是使用的都是默认值,我们当然也希望对其进行各种自定义的配置
创建一个OpenAPI 的bean,配置文档名称等信息
package com.wenge.business.config;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.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;/*** Swagger 文档配置** @author wkl*/
@Configuration
public class SpringDocAutoConfiguration {@Beanpublic OpenAPI openApi() {return new OpenAPI().info(new Info().title("这是标题").description("这是备注").version("这是版本").license(new License().name("这是许可证").url("这是许可证链接")).contact(new Contact().name("这是作者").url("这是作者链接").email("这是作者email")));}
}

2、配置文档分组
用来配置分组的,假如你有多类controller一类以/tacticsInfo为前缀分组,一类以/admin为前缀,就可以将其配置为两个分组。很多时候我们只有一个分组,所以就不需要下面的配置。
@Beanpublic GroupedOpenApi publicApi() {return GroupedOpenApi.builder().group("tacticsInfo").pathsToMatch("/tacticsInfo/**")//以/tacticsInfo开头的的api都进这个分组.build();}@Beanpublic GroupedOpenApi otherApi() {return GroupedOpenApi.builder().group("other").pathsToMatch("/admin/**")//以/tacticsInfo开头的的api都进这个分组.build();}// @Bean
// public GroupedOpenApi otherApi() {
// return GroupedOpenApi.builder()
// .group("other")
// .pathsToMatch("/**/**")//这样配置,那就是所有的api都进这个分组
// .build();
// }
可以通过右上角的下拉框选择要展示的group。

3、springdoc的配置参数
1. 基础配置
API 文档路径-springdoc.api-docs.path
springdoc.api-docs.path- 作用:指定 OpenAPI JSON 文档的访问路径。
- 默认值:
/v3/api-docs - 示例:
springdoc.api-docs.path=/openapi
Swagger UI 路径-springdoc.swagger-ui.path
springdoc.swagger-ui.path- 作用:指定 Swagger UI 的访问路径。
- 默认值:
/swagger-ui.html - 示例:
springdoc.swagger-ui.path=/docs
是否启用 API 文档-springdoc.api-docs.enabled
springdoc.api-docs.enabled- 作用:启用或禁用 OpenAPI 文档生成功能。
- 默认值:
true - 示例:
springdoc.api-docs.enabled=false
是否启用 Swagger UI-springdoc.swagger-ui.enabled
springdoc.swagger-ui.enabled- 作用:启用或禁用 Swagger UI。
- 默认值:
true - 示例:
springdoc.swagger-ui.enabled=false
2. 全局元信息-info
应用标题-springdoc.info.title
springdoc.info.title- 作用:设置 API 文档的标题。
- 默认值:空
- 示例:
springdoc.info.title=用户管理系统
应用描述-springdoc.info.description
springdoc.info.description- 作用:设置 API 文档的描述信息。
- 默认值:空
- 示例:
springdoc.info.description=用户管理相关的 API 文档
版本号-pringdoc.info.version
springdoc.info.version- 作用:设置 API 文档的版本号。
- 默认值:空
- 示例:
springdoc.info.version=1.0.0
联系人信息-springdoc.info.contact
springdoc.info.contact.namespringdoc.info.contact.emailspringdoc.info.contact.url- 作用:设置文档的联系人信息(姓名、邮箱、URL)。
- 默认值:空
- 示例:
springdoc.info.contact.name=John Doe springdoc.info.contact.email=john.doe@example.com springdoc.info.contact.url=http://example.com
许可信息-pringdoc.info.license
springdoc.info.license.namespringdoc.info.license.url- 作用:设置文档的许可证信息(名称、URL)。
- 默认值:空
- 示例:
springdoc.info.license.name=Apache 2.0 springdoc.info.license.url=https://www.apache.org/licenses/LICENSE-2.0
3. 分组与模块化
分组支持-springdoc.group-configs
springdoc.group-configs- 作用:为不同的控制器或包生成独立的 API 文档分组。
- 示例:
springdoc.group-configs[0].group=user-api springdoc.group-configs[0].packages-to-scan=com.example.user springdoc.group-configs[1].group=order-api springdoc.group-configs[1].packages-to-scan=com.example.order
扫描包范围-springdoc.packages-to-scan
springdoc.packages-to-scan- 作用:指定需要扫描的包范围,用于生成 API 文档。
- 默认值:当前应用程序的所有包。
- 示例:
springdoc.packages-to-scan=com.example.api
排除特定路径-springdoc.paths-to-exclude
springdoc.paths-to-exclude- 作用:排除某些路径,不将其包含在生成的 API 文档中。
- 默认值:无
- 示例:
springdoc.paths-to-exclude=/admin/**
4. 安全配置
全局安全方案
springdoc.api-docs.security-schemes- 作用:定义全局的安全方案(如 OAuth2、API Key 等)。
- 示例:
springdoc.api-docs.security-schemes[0].name=ApiKeyAuth springdoc.api-docs.security-schemes[0].type=apiKey springdoc.api-docs.security-schemes[0].in=header
全局安全要求
springdoc.api-docs.security-requirements- 作用:定义全局的安全要求。
- 示例:
springdoc.api-docs.security-requirements[0]=ApiKeyAuth
5. 自定义行为
缓存控制
springdoc.cache.disabled- 作用:禁用 API 文档的缓存。
- 默认值:
false - 示例:
springdoc.cache.disabled=true
排序规则
springdoc.default-flat-param-object- 作用:是否将参数对象展平为单个参数。
- 默认值:
false - 示例:
springdoc.default-flat-param-object=true
服务器地址-pringdoc.servers
springdoc.servers- 作用:定义 API 的服务器地址列表。
- 示例:
springdoc.servers[0].url=http://localhost:8080 springdoc.servers[0].description=本地开发环境 springdoc.servers[1].url=https://api.example.com springdoc.servers[1].description=生产环境
6. 高级配置
自定义 OpenAPI 对象
- 作用:通过 Java 配置类自定义 OpenAPI 对象。
- 示例:
@Bean public OpenAPI customOpenAPI() {return new OpenAPI().info(new Info().title("用户管理系统").version("1.0").description("用户管理相关的 API 文档")).addServersItem(new Server().url("http://localhost:8080").description("本地开发环境")); }
自定义 Swagger UI
- 作用:通过 Java 配置类自定义 Swagger UI 行为。
- 示例:
@Bean public SwaggerUiConfigProperties swaggerUiConfig() {SwaggerUiConfigProperties config = new SwaggerUiConfigProperties();config.setPath("/custom-docs");return config; }
7. 总结
以下是 springdoc 配置参数的分类总结:
| 类别 | 参数 | 作用 |
|---|---|---|
| 基础配置 | springdoc.api-docs.path, springdoc.swagger-ui.path, springdoc.api-docs.enabled | 配置 API 文档路径、Swagger UI 路径及启用状态。 |
| 全局元信息 | springdoc.info.title, springdoc.info.description, springdoc.info.version | 设置 API 文档的标题、描述、版本等基本信息。 |
| 分组与模块化 | springdoc.group-configs, springdoc.packages-to-scan, springdoc.paths-to-exclude | 支持分组、限制扫描范围、排除特定路径。 |
| 安全配置 | springdoc.api-docs.security-schemes, springdoc.api-docs.security-requirements | 定义全局安全方案和要求。 |
| 自定义行为 | springdoc.cache.disabled, springdoc.default-flat-param-object, springdoc.servers | 控制缓存、参数对象展平、服务器地址等高级功能。 |
| 高级配置 | 自定义 OpenAPI 对象、Swagger UI 配置 | 通过代码方式实现更灵活的定制。 |
4、SpringDoc注解
1. 核心注解
@Tag
-
作用:为控制器或方法分组,便于组织和分类 API。
-
常用属性:
name:标签名称。description:标签描述信息。
-
示例:
@Tag(name = "策略库接口",description = "这是策略库的所有接口")@RestController@RequestMapping("/tacticsInfo")public class TacticsInfoController extends BaseController{// ...}

2. 方法级别注解
@Operation
- 作用:描述一个 API 方法的功能。
- 常用属性:
summary:方法的简短描述。description:方法的详细描述。responses:定义可能的响应结果。deprecated:标记方法是否已废弃。
- 示例:
@Operation(summary = "查询策略库:tactics_info列表",description = "查询策略库:tactics_info列表-list接口")@RequiresPermissions("business:tacticsInfo:list")@GetMapping("/list")public TableDataInfo list(TacticsInfo tacticsInfo){// ... }

@ApiResponse 和 @ApiResponses
- 作用:描述 API 方法的响应结果。
- 常用属性:
responseCode:HTTP 状态码。description:响应描述信息。content:响应的内容类型(如 JSON、XML)。
- 示例:
@Operation(summary = "创建用户", description = "根据用户信息创建新用户") @ApiResponses({@ApiResponse(responseCode = "200", description = "成功创建用户"),@ApiResponse(responseCode = "400", description = "请求参数错误"),@ApiResponse(responseCode = "500", description = "服务器内部错误") }) @PostMapping public ResponseEntity<User> createUser(@RequestBody User user) {// ... }
3. 参数相关注解
@Parameter
- 作用:描述方法参数的含义。
- 常用属性:
name:参数名称。description:参数描述信息。required:是否必填。example:参数示例值。in:参数位置(如path、query、header等)。
- 示例:
@Operation(summary = "根据 ID 获取用户") @GetMapping("/{id}") public User getUserById(@Parameter(name = "id", description = "用户 ID", required = true, example = "1") @PathVariable Long id) {// ... }
@Parameters
- 作用:描述多个参数。
- 示例:
@Operation(summary = "搜索用户") @Parameters({@Parameter(name = "name", description = "用户名", in = ParameterIn.QUERY),@Parameter(name = "age", description = "用户年龄", in = ParameterIn.QUERY) }) @GetMapping("/search") public List<User> searchUsers(@RequestParam String name, @RequestParam Integer age) {// ... }
4. 实体模型相关注解
@Schema
- 作用:描述实体类或字段的信息。
- 常用属性:
description:模型或字段的描述信息。example:字段示例值。required:字段是否必填。type:字段的数据类型。format:字段的格式(如date-time、email等)。
- 示例:
@Schema(description = "用户的基本信息") public class User {@Schema(description = "用户 ID", example = "1", required = true)private Long id;@Schema(description = "用户名", example = "John Doe", required = true)private String name;@Schema(description = "用户年龄", example = "25")private Integer age;// getters and setters }
5. 其他注解
@Hidden
- 作用:隐藏某个类、方法或参数,不将其包含在生成的文档中。
- 示例:
@Hidden @GetMapping("/internal") public String internalEndpoint() {return "This endpoint is ignored by springdoc."; }
6. 配置相关注解(不常用)
@OpenAPIDefinition
- 作用:全局配置 OpenAPI 文档的元信息。这个不常用,还是常用配置文件类型的
- 常用属性:
info:文档的基本信息(标题、版本、描述等)。tags:全局标签定义。servers:API 的服务器地址。
- 示例:
@OpenAPIDefinition(info = @Info(title = "用户管理系统", version = "1.0", description = "用户相关的 API 文档"),tags = {@Tag(name = "用户管理", description = "与用户相关的操作")},servers = {@Server(url = "http://localhost:8080", description = "本地开发环境")} ) @SpringBootApplication public class Application {public static void main(String[] args) {SpringApplication.run(Application.class, args);} }
7. 总结
以下是 springdoc 常用注解的分类总结:
| 注解 | 作用 |
|---|---|
| @Tag | 为控制器或方法分组,便于组织和分类 API。 |
| @Operation | 描述 API 方法的功能。 |
| @ApiResponse | 描述单个响应结果。 |
| @Parameter | 描述方法参数的含义。 |
| @Schema | 描述实体类或字段的信息。 |
| @Hidden | 隐藏某个类、方法或参数,不包含在生成的文档中。 |
| @OpenAPIDefinition | 全局配置 OpenAPI 文档的元信息(标题、版本、描述等)。 |
四、在实际项目上如何使用
1、导包
在springboot中使用springdoc起步非常容易,只需要引入其starter即可
<dependency><groupId>org.springdoc</groupId><artifactId>springdoc-openapi-ui</artifactId><version>1.7.0</version> <!-- 版本可替换 -->
</dependency>
2、写配置类
1)、配置实体类
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.boot.context.properties.NestedConfigurationProperty;
import io.swagger.v3.oas.models.info.Contact;
import io.swagger.v3.oas.models.info.License;/*** Swagger 配置属性** @author wkl*/
@ConfigurationProperties(prefix = "springdoc")
public class SpringDocProperties
{/*** 网关*/private String gatewayUrl;/*** 文档基本信息*/@NestedConfigurationPropertyprivate InfoProperties info = new InfoProperties();/*** <p>* 文档的基础属性信息* </p>** @see io.swagger.v3.oas.models.info.Info** 为了 springboot 自动生产配置提示信息,所以这里复制一个类出来*/public static class InfoProperties{/*** 标题*/private String title = null;/*** 描述*/private String description = null;/*** 联系人信息*/@NestedConfigurationPropertyprivate Contact contact = null;/*** 许可证*/@NestedConfigurationPropertyprivate License license = null;/*** 版本*/private String version = null;public String getTitle(){return title;}public void setTitle(String title){this.title = title;}public String getDescription(){return description;}public void setDescription(String description){this.description = description;}public Contact getContact(){return contact;}public void setContact(Contact contact){this.contact = contact;}public License getLicense(){return license;}public void setLicense(License license){this.license = license;}public String getVersion(){return version;}public void setVersion(String version){this.version = version;}}public String getGatewayUrl(){return gatewayUrl;}public void setGatewayUrl(String gatewayUrl){this.gatewayUrl = gatewayUrl;}public InfoProperties getInfo(){return info;}public void setInfo(InfoProperties info){this.info = info;}
}
2)、配置类
import java.util.ArrayList;
import java.util.List;
import org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean;
import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;
import org.springframework.boot.context.properties.EnableConfigurationProperties;
import org.springframework.context.annotation.Bean;
import com.wenge.common.swagger.config.properties.SpringDocProperties;
import io.swagger.v3.oas.models.Components;
import io.swagger.v3.oas.models.OpenAPI;
import io.swagger.v3.oas.models.info.Info;
import io.swagger.v3.oas.models.security.SecurityRequirement;
import io.swagger.v3.oas.models.security.SecurityScheme;
import io.swagger.v3.oas.models.servers.Server;/*** Swagger 文档配置** @author ruoyi*/
@EnableConfigurationProperties(SpringDocProperties.class)
@ConditionalOnProperty(name = "springdoc.api-docs.enabled", havingValue = "true", matchIfMissing = true)
public class SpringDocAutoConfiguration
{@Bean@ConditionalOnMissingBean(OpenAPI.class)public OpenAPI openApi(SpringDocProperties properties){return new OpenAPI().components(new Components()// 设置认证的请求头.addSecuritySchemes("apikey", securityScheme())).addSecurityItem(new SecurityRequirement().addList("apikey")).info(convertInfo(properties.getInfo())).servers(servers(properties.getGatewayUrl()));}public SecurityScheme securityScheme(){return new SecurityScheme().type(SecurityScheme.Type.APIKEY).name("Authorization").in(SecurityScheme.In.HEADER).scheme("Bearer");}private Info convertInfo(SpringDocProperties.InfoProperties infoProperties){Info info = new Info();info.setTitle(infoProperties.getTitle());info.setDescription(infoProperties.getDescription());info.setContact(infoProperties.getContact());info.setLicense(infoProperties.getLicense());info.setVersion(infoProperties.getVersion());return info;}public List<Server> servers(String gatewayUrl){List<Server> serverList = new ArrayList<>();serverList.add(new Server().url(gatewayUrl));return serverList;}
}
3、编写配置参数
springdoc:api-docs:path: /v3/api-docsswagger-ui:path: /swagger-ui.htmlenabled: trueoperationsSorter: methodshow-actuator: true相关文章:
SpringBoot之如何集成SpringDoc最详细文档
文章目录 一、概念解释1、OpenAPI2、Swagger3、Springfox4、Springdoc5. 关系与区别 二、SpringDoc基本使用1、导包2、正常编写代码,不需要任何注解3、运行后访问下面的链接即可 三、SpringDoc进阶使用1、配置文档信息2、配置文档分组3、springdoc的配置参数**1. 基…...
Oracle 数据迁移至 GaussDB 注意事项
将数据从 Oracle 迁移到 GaussDB(华为分布式数据库)时,需充分考虑架构差异、语法兼容性、数据一致性等核心问题。以下是关键注意事项及操作建议: 一、迁移前的准备工作 兼容性评估 语法差异:Oracle 使用 PL/SQL&#x…...
【智能体】| 知识库、RAG概念区分以及智能体是什么
文章目录 前言简介大模型“幻觉”问题如何解决“幻觉”问题? RAG、智能体、RAG智能体概念什么是检索增强型生成(RAG)模拟简单的RAG场景 AI系统中的智能体是什么什么是Agentic RAG?Agentic RAG如何工作?Agentic RAG架构…...
二分查找的应用
什么时候用二分查找? 数据具有二段性的时候 第一题: 题解代码: class Solution { public:int search(vector<int>& nums, int target) {int left 0,right nums.size()-1;while(left<right){int mid left (right-left)/2;//中…...
Android Compose 框架基础按钮模块深度剖析(四)
Android Compose 框架基础按钮模块深度剖析 一、引言 在现代 Android 应用开发中,Android Compose 框架以其声明式编程范式和简洁高效的开发体验,逐渐成为开发者构建用户界面的首选。而注解在 Android Compose 框架中扮演着至关重要的角色,…...
redis搭建一主一从+keepalived(虚拟IP)实现高可用
redis搭建一主一从keepalived(虚拟IP)实现高可用 前提 有两台机器:如 10.50.3.141 10.50.3.142,虚拟ip如:10.50.3.170 安装redis(两台机器执行): # 启用Remi仓库(CentOS 7) sudo yum install…...
【Function】Azure Function通过托管身份或访问令牌连接Azure SQL数据库
【Function】Azure Function通过托管身份或访问令牌连接Azure SQL数据库 推荐超级课程: 本地离线DeepSeek AI方案部署实战教程【完全版】Docker快速入门到精通Kubernetes入门到大师通关课AWS云服务快速入门实战目录 【Function】Azure Function通过托管身份或访问令牌连接Azu…...
MySQL日志全解析:类型、用途与运维实践
引言 MySQL作为最流行的关系型数据库之一,其日志系统是运维人员理解数据库状态、排查问题、保证数据安全的核心工具。不同类型的日志记录了数据库活动、错误信息、数据变更等关键内容。本文将深入解析MySQL各类日志的作用、配置参数及运维注意事项,帮助…...
《算法笔记》9.2小节——数据结构专题(2)->二叉树的遍历 问题 A: 复原二叉树(同问题 C: 二叉树遍历)
题目描述 小明在做数据结构的作业,其中一题是给你一棵二叉树的前序遍历和中序遍历结果,要求你写出这棵二叉树的后序遍历结果。 输入 输入包含多组测试数据。每组输入包含两个字符串,分别表示二叉树的前序遍历和中序遍历结果。每个字符串由…...
小程序开发中的用户反馈收集与分析
我们在开发小程序的过程中根据开发过程中的代码及业务场景,以下是针对需求管理系统的用户反馈收集与分析方案设计: 需求管理系统用户反馈收集与分析方案 一、反馈数据模型设计 // 新增Feedback模型(app/admin/model/Feedback.php) namespace app\admin\model; use think\…...
Flink 通过 Chunjun Oracle LogMiner 实时读取 Oracle 变更日志并写入 Doris 的方案
文章目录 一、 技术背景二、 关键技术1、 Oracle LogMiner2、 Chunjun 的 LogMiner 关键流程3、修复 Chunjun Oracle LogMiner 问题 一、 技术背景 在大数据实时同步场景中,需要将 Oracle 数据库的变更数据(CDC) 采集并写入 Apache Doris&am…...
WordPress系统获取webshell的攻略
一.后台修改模板拿WebShell 1.进入Vulhub靶场并执⾏以下命令开启靶场;在浏览器中访问并安装好 #执⾏命令 cd /vulhub/wordpress/pwnscriptum docker-compose up -d 2. 修改其WP的模板,登陆WP后点击 【外 观】 --》 【编辑】 --》 404.php 3.插入一句话木…...
JMeter基本介绍
Apache JMeter 工具详解 一、JMeter 简介 JMeter 是 Apache 基金会开源的 Java 应用程序,主要用于 性能测试、负载测试 和 功能测试。它通过对服务器或网络资源模拟多种负载条件(如并发用户、持续压力),帮助评估系统性能指标&am…...
npm 安装 pnpm 的详细步骤及注意事项
一、安装步骤 1.全局安装 pnpm npm install -g pnpm2.验证安装 pnpm -v输出版本号即表示安装成功。 二、升级 pnpm 若已安装旧版本,可通过以下命令升级: npm install -g pnpmlatest三、配置镜像加速 设置淘宝镜像 pnpm config set registry http…...
蓝桥杯2023年第十四届省赛真题-子矩阵
题目来自DOTCPP: 暴力思路(两个测试点超时): 题目要求我们求出子矩阵的最大值和最小值的乘积,我们可以枚举矩阵中的所有点,以这个点为其子矩阵的左上顶点,然后判断一下能不能构成子矩阵。如果可…...
如何在 Node.js 中使用 .env 文件管理环境变量 ?
Node.js 应用程序通常依赖于环境变量来管理敏感信息或配置设置。.env 文件已经成为一种流行的本地管理这些变量的方法,而无需在代码存储库中公开它们。本文将探讨 .env 文件为什么重要,以及如何在 Node.js 应用程序中有效的使用它。 为什么使用 .env 文…...
Redis BitMap 用户签到
Redis Bitmap Bitmap(位图)是 Redis 提供的一种用于处理二进制位(bit)的特殊数据结构,它基于 String 类型,每个 bit 代表一个布尔值(0 或 1),可以用于存储大规模的二值状…...
未来办公与生活的新范式——智慧园区
在信息化与智能化技术飞速发展的今天,智慧园区作为一种新兴的城市发展形态,正逐步成为推动产业升级、提升城市管理效率、改善居民生活质量的重要力量。智慧园区不仅融合了先进的信息技术,还深刻体现了可持续发展的理念,为园区内的…...
Hugging Face预训练GPT微调ChatGPT(微调入门!新手友好!)
Hugging Face预训练GPT微调ChatGPT(微调入门!新手友好!) 在实战中,⼤多数情况下都不需要从0开始训练模型,⽽是使⽤“⼤⼚”或者其他研究者开源的已经训练好的⼤模型。 在各种⼤模型开源库中,最…...
【CSS3】化神篇
目录 平面转换平移旋转改变旋转原点多重转换缩放倾斜 渐变线性渐变径向渐变 空间转换平移视距旋转立体呈现缩放 动画使现步骤animation 复合属性animation 属性拆分逐帧动画多组动画 平面转换 作用:为元素添加动态效果,一般与过渡配合使用 概念&#x…...
Unity音频混合器如何暴露参数
音频混合器是Unity推荐管理音效混音的工具,那么如何使用代码对它进行管理呢? 首先我在AudioMixer的Master组中创建了BGM和SFX的分组,你也可以直接用Master没有问题。 这里我以BGM为例,如果要在代码中进行使用就需要将参数暴露出去…...
Vue keepalive学习用法
在Vue中,<keep-alive>的include属性用于指定需要缓存的组件,其实现方式如下: 1. 基本用法 • 字符串形式:通过逗号分隔组件名称,匹配到的组件会被缓存。 <keep-alive include"ComponentA,ComponentB&…...
5-1 使用ECharts将MySQL数据库中的数据可视化
方法一:使用Python Flask框架搭建API 对于技术小白来说,使用ECharts将MySQL数据库中的数据可视化需要分步骤完成。以下是详细的实现流程: 一、技术架构 后端服务:使用Python Flask框架搭建API(简单易学ÿ…...
构建下一代AI Agent:自动化开发与行业落地全解析
1. 下一代AI Agent:概念与核心能力 核心能力描述技术支撑应用价值自主性独立规划与执行任务,无需持续人工干预决策树、强化学习、目标导向规划减少人工干预,提高任务执行效率决策能力评估多种方案并选择最优解决方案贝叶斯决策、多目标优化、…...
如何理解分布式光纤传感器?
关键词:OFDR、分布式光纤传感、光纤传感器 分布式光纤传感器是近年来备受关注的前沿技术,其核心在于将光纤本身作为传感介质和信号传输介质,通过解析光信号在光纤中的散射效应,实现对温度、应变、振动等物理量的连续、无盲区、高…...
四、小白学JAVA-石头剪刀布游戏
1、如何从控制台获取用户输入 import java.util.Scanner;public class Main {public static void main(String[] args) {// 石头剪刀布的思路// 1 2 3 石头 剪刀 布Scanner scanner new Scanner(System.in);System.out.println("请出拳:1.石头 2.剪刀 3.布【…...
【一起来学kubernetes】21、Secret使用详解
Secret 的详细介绍 Secret 是 Kubernetes 中用于存储和管理敏感信息(如密码、令牌、密钥等)的资源对象。Secret的设计目的是为了安全地存储和传输敏感信息,如密码、API密钥、证书等。这些信息通常不应该直接硬编码在配置文件或镜像中&#x…...
css重点知识汇总(一)
css重点知识汇总(一) 引入css的不同方式 link 通过src来获取相应的css资源。除了获取css之外还可以获取其他资源,例如js在页面载入是同步下载可以通过js对dom操作来改变css import css3引入的新方法只能引入css资源需要页面完全载入后才…...
PMP-项目运行环境
你好!我是 Lydia-穎穎 ♥感谢你的陪伴与支持 ~~~ 欢迎一起探索未知的知识和未来,现在lets go go go!!! 1. 影响项目的要素 项目存在在不同的环境下,环境对于项目的交付产生不同的影响。需了解环境对于项目的影响,采取相应措施应对…...
shell 脚本搭建apache
#!/bin/bash # Set Apache version to install ## author: yuan# 检查外网连接 echo "检查外网连接..." ping www.baidu.com -c 3 > /dev/null 2>&1 if [ $? -eq 0 ]; thenecho "外网通讯良好!" elseecho "网络连接失败&#x…...
