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.name
springdoc.info.contact.email
springdoc.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.name
springdoc.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. 基…...
Transaction rolled back because it has been marked as rollback-only问题解决
transaction rolled back because it has been marked as rollback-only 简略总结> 发生场景:try-catch多业务场景 发生原因:业务嵌套,事务管理混乱,外层业务与内层业务抛出异常节点与回滚节点不一致。 解决方式:修…...
单片机写的小液晶屏驱动+汉字滚屏
单片机写的小液晶屏驱动汉字滚屏 stm32f401freertos内置HZK16 单片机汉字滚屏...
SpringBoot整合LangChain4j操作AI大模型实战详解
一、引言 在当今这个人工智能飞速发展的时代,AI大模型已经逐渐渗透到我们生活的方方面面,为企业和开发者带来了前所未有的机遇。然而,如何高效地接入并利用这些AI大模型,成为了摆在许多开发者面前的一道难题。SpringBoot作为一款…...
深度解析 | Android 13 Launcher3分页指示器改造:横线变圆点实战指南
一、需求背景与技术挑战 在Android 13系统定制开发中,我们面临将Launcher3桌面从传统双层架构优化为现代单层布局的挑战。原生系统采用的分页横线指示器在视觉呈现上存在两点不足: 风格陈旧不符合Material You设计规范 空间占用较大影响屏幕利用率 通…...
【Qt】private槽函数可以被其他类中的信号连接
private槽函数可以被其他类中的信号连接。 即使 B 类的槽函数是 private 的,A 类通过信号连接 B 类的槽函数也没有问题。这是因为 Qt 的信号和槽机制是通过元对象系统(Meta-Object System)实现的,而不是直接调用函数。只要信号和…...
C语言每日一练——day_7
引言 针对初学者,每日练习几个题,快速上手C语言。第七天。(连续更新中) 采用在线OJ的形式 什么是在线OJ? 在线判题系统(英语:Online Judge,缩写OJ)是一种在编程竞赛中用…...
Python --**kwargs
在 Python 中,**kwargs 是一个特殊语法,用于在函数定义中接收任意数量的关键字参数(即键值对参数),并将这些参数以字典形式存储。它是 Python 中处理动态参数的强大工具,适用于需要灵活传递参数的场景。 1.…...
网络编程之客户端通过服务器与另外一个客户端交流
服务器使用select模型搭建,客户端1使用线程搭建,客户端2使用poll模型搭建, 使用时需要先运行服务器,具体编译可看我最后的图片 head.h头文件 #ifndef __HEAD_H_ #define __HEAD_H_ #include <stdio.h> #include <string…...
mybatis集合映射association与collection
官方文档:MyBatis的一对多关联关系 一、用途 一对一:association 一对多:collection 二、association 比较容易理解,可参考官方文档 三、collection <?xml version"1.0" encoding"UTF-8"?> &l…...
windows克隆项目找不到,修改git bash中存储的账号密码
git clone项目找不到,提示:remote: The project you were looking for could not be found. 有可能是地址错误、没有权限、账号密码错误 1.地址错误 从新检查git地址,确保地址是正确的。 2.没有权限 确保你有访问该项目的权限 3.账号密码…...
Linux中安装redis
Redis的安装包,从官方下载下来的是c语言的源码包,我们需要自己编译安装。具体操作步骤如下: 安装redis 上传redis资源包 安装C语言的编译环境 gcc yum install -y gcc-c 解压redis源码在当前目录 tar -zxvf redis-6.2.4.tar.gz 进入解压目录…...
Springboot项目打包成war包
1、首先创建一个springboot工程,然后我们改造启动类如: import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.boot.builder.SpringApplicationBuil…...
Word:双栏排版操作步骤及注意事项
将word单栏文字排版为双栏是论文投稿前的重要步骤,也是非常容易出错的一步。但事实上排版的操作并不复杂,本篇博客旨在把操作过程及注意事项简单记录下来,便于日后浏览和查询。 【Step1】打开“显示/隐藏段落标记” (ctrl*&#…...
ArcGIS10. 8简介与安装,附下载地址
目录 ArcGIS10.8 1. 概述 2. 组成与功能 3. 10.8 特性 下载链接 安装步骤 1. 安装准备 2. 具体步骤 3.补丁 其他版本安装 ArcGIS10.8 1. 概述 ArcGIS 10.8 是由美国 Esri 公司精心研发的一款功能强大的地理信息系统(GIS)平台。其核心功能在于…...
MySQL:数据库基础
数据库基础 1.什么是数据库?2.为什么要学习数据库?3.主流的数据库(了解)4.服务器,数据库,表之间的关系5.数据的逻辑存储6.MYSQL架构7.存储引擎 1.什么是数据库? 数据库(Database,简称DB)&#x…...
数据结构-----初始数据结构、及GDB调试
一、数据结构核心概念 相互之间存在一种或多种特定关系的数据元素的集合。 1. 数据结构定义 // 嵌入式场景示例:传感器网络节点结构 struct SensorNode {uint16_t node_id; // 2字节float temperature; // 4字节uint32_t timestamp; // 4字节struct Se…...
go面向对象编程三大特性,封装、继承和多态
1.简介 go具有面向对象编程的封装、继承和多态的特性,只是实现的方式和其它OOP语言不一样,下面看下go的三大特性是如何实现的。 2.封装 2.1基本介绍 封装就是把抽象出的字段和对字段的操作封装在一起,数据被保护在内部,程序的其它包只能通过被授权的操作(方法),才能…...
华为ISC+战略规划项目数字化转型驱动的智慧供应链革新(169页PPT)(文末有下载方式)
资料解读:华为ISC战略规划项目数字化转型驱动的智慧供应链革新 详细资料请看本解读文章的最后内容。 华为的ISC战略规划项目是其供应链数字化转型的核心,旨在通过智慧供应链的革新,提升企业的竞争力和运营效率。本文将从多个维度详细解读这…...
算法刷题记录——LeetCode篇(10) [第901~1000题](持续更新)
(优先整理热门100及面试150,不定期持续更新,欢迎关注) 994. 腐烂的橘子 在给定的 m x n 网格 grid 中,每个单元格可以有以下三个值之一: 值 0 代表空单元格;值 1 代表新鲜橘子;值 2 代表腐烂的橘子。 每…...
Python中的字典:深度解析与应用实践
一、字典的本质与特性 Python字典(Dictionary)是以**键值对(Key-Value Pair)**形式存储数据的无序集合,使用大括号{}定义。其核心特性包括: 快速查找:基于哈希表实现,通过键&#…...
jmeter配件元素
jmeter配件元素 CSV Data Set Config名词解释测试场景Recycle on EOF:False配置测试结果 Recycle on EOF:True配置测试结果 Sharing mode:All Threads配置测试结果 Sharing mode:Current thread group配置测试结果 Sharing mode:Current thread配置测试结果 HTTP Header Manage…...
VSCode + CMake
参考文献: 如何用 GCC, CMake 和 Make 编译C/C代码Windows 上的 Linux 子系统:WSLWSL:桌面 UI 远程连接 RDP 配置 VScode 文章目录 CMake 配置VSCode 配置launch.jsontask.jsonc_cpp_properties.json CMake 配置 编写如下的 CmakeLists.t…...
JVM的一些知识
JVM简介 JVM 是 Java Virtual Machine 的简称,意为 Java 虚拟机。 虚拟机是指通过软件模拟的具有完整硬件功能的、运行在一个完全隔离的环境中的完整计算机系统。常见的虚拟机:JVM、VMwave、Virtual Box。 JVM 和其他两个虚拟机的区别: VMw…...
SpringCloud网关:Gateway路由配置与过滤器链
文章目录 引言一、Gateway基本架构二、路由配置方式2.1 配置文件方式2.2 Java代码方式 三、内置断言工厂四、内置过滤器工厂4.1 请求路径相关过滤器4.2 请求和响应头过滤器4.3 功能性过滤器 五、自定义过滤器5.1 自定义GatewayFilter5.2 自定义过滤器工厂 六、全局过滤器总结 引…...
Git 分支使用规范全解(多人协作开发适用)
🚀 Git 分支使用规范全解(多人协作开发适用) 本文将为你梳理一套清晰、标准、适合企业/团队使用的 Git 分支管理策略,适用于前后端、边缘端、AI项目等多种场景。 🧩 为什么要规范分支管理? 防止多人协作混乱、冲突频发清晰区分:开发中 / 待发布 / 已上线 的版本快速定…...
【华三】路由器交换机忘记登入密码或super密码的重启操作
【华三】路由器交换机忘记登入密码或super密码的重启操作 背景步骤跳过认证设备:路由器重启设备翻译说明具体操作 跳过当前系统配置重启设备具体操作 背景 当console口的密码忘记,或者说本地用户的密码忘记,其实这时候是登入不了路由器的&am…...
Linux驱动开发进阶 - 文件系统
文章目录 1、前言2、学习目标3、VFS虚拟文件系统3.1、超级块(Super Block)3.2、dentry3.3、inode3.4、file 4、文件系统的挂载5、文件系统的注册5.1、文件系统的注册过程5.1.2、定义文件系统类型5.1.3、注册文件系统5.1.4、注销文件系统 5.2、文件系统的…...
Mac:JMeter 下载+安装+环境配置(图文详细讲解)
📌 下载JMeter 下载地址:https://jmeter.apache.org/download_jmeter.cgi 📌 无需安装 Apache官网下载 JMeter 压缩包,无需安装,下载解压后放到自己指定目录下即可。 按我自己的习惯,我会在用户 jane 目…...
蓝桥杯备考:图论之Prim算法
嗯。通过我们前面的学习,我们知道了,一个具有n个顶点的连通图,它的生成树包括n-1个边,如果边多一条就会变成图,少一条就不连通了 接下来我们来学一下把图变成生成树的一个算法 Prim算法,我们从任意一个结…...
Linux 文件操作-标准IO函数3- fread读取、fwrite写入、 fprintf向文件写入格式化数据、fscanf逐行读取格式化数据的验证
目录 1. fread 从文件中读取数据 1.1 读取次数 每次读取字节数 < 原内容字节数 1.2 读取次数 每次读取字节数 > 原内容字节数 2.fwrite 向文件中写入数据 2.1写入字符串验证 2.2写入结构体验证 3. fprintf 将数据写入到指定文件 4. fscanf 从文件中逐行读取内容…...
汽车一键启动系统使用方便,舒适出行,轻松匹配
汽车一键启动系统 系统定义 移动管家汽车一键启动系统是装置在智能汽车上的一部分,是实现简约打火和熄火过程的一个按钮装置。它可以在原车钥匙锁头的位置改装,也能独立面板改装,现在很多高低配置的车辆都可安装。 功能特点 基本功能 启…...
python函数的多种参数使用形式
目录 1. 位置参数(Positional Arguments) 2. 关键字参数(Keyword Arguments) 3. 默认参数(Default Arguments) 4. 可变参数(Variable Positional Arguments) 5. 关键字可变参数&…...
Qt带参数的信号和槽,以及信号与槽的连接方式
1.带参数的信号和槽 Qt的信号与槽也支持带有参数,同时也可以支持重载 此处我们要求,信号函数的参数列表要和对应连接的槽函数参数列表一致 此时信号触发,调用到槽函数的时候,信号函数中的实参就能够被传递到槽函数的形参中 示例…...
深度解析ECharts.js:构建现代化数据可视化的利器
引言:数据可视化的新时代挑战 在数字化转型浪潮中,数据可视化已成为企业决策和用户体验的关键环节。面对海量数据的呈现需求,传统表格已无法满足用户对直观洞察的渴求。作为百度开源的JavaScript可视化库,ECharts.js凭借其强大的…...
Flutter:页面滚动,导航栏背景颜色过渡动画
记录:导航默认透明,页面发生滚动后,导航背景色由0-1,过渡到白色背景。 view import package:ducafe_ui_core/ducafe_ui_core.dart; import package:flutter/material.dart; import package:get/get.dart; import package:redo…...
一文了解ThreadLocal
什么是ThreadLocal? ThreadLocal是每个线程私有的,线程可以把自己的私有数据放到ThreadLocal里面,不用担心其他线程访问到自己ThreadLocal。 通过set()方法将值存入ThreadLocal或者修改值,get()方法取出值,remove()方…...
日常学习开发记录-input组件
实现 1.实现2.inline-table和table-cell实现2.1 表格布局的特性2.2 示例 3.clear清除事件未生效3.1 原因3.2 解决 4. 增加type为text和textarea4.1 rows,autosize的实现 5.拓展-composition事件 1.实现 <template><div class"my-input":class"{is-dis…...
【数据库系统原理】简答题
真题 2024-10 31.数据模型的三大要素是什么? 32.简述关系模型的参照完整性规则。 33.什么是视图?视图的作用是什么? 34.简述两个实体型之间联系的三种形式,并举例说明。 35.什么是数据库备份?MySQL使用什么语句实现备份与恢复数据库中表的数据? 2024-04 31.请解释数据…...
20250319在荣品的PRO-RK3566开发板的buildroot系统下使用集成的QT应用调试串口UART3
stty -F /dev/ttyS3 115200 -echo cat /dev/ttyS3 & echo serialdata > /dev/ttyS3 20250319在荣品的PRO-RK3566开发板的buildroot系统下使用集成的QT应用调试串口UART3 2025/3/19 14:17 缘起:在荣品的PRO-RK3566开发板的buildroot系统下,在命令…...
C#基于MVC模式实现TCP三次握手,附带简易日志管理模块
C#基于MVC模式实现TCP三次握手 1 Model1.1 ServerModel1.2 ClientModel1.3 配置参数模块1.4 日志管理模块1.4.1 数据结构1.4.1 日志管理工具类1.4.1 日志视图展示1.4.1.1 UcLogManage.cs1.4.1.2 UcLogManage.Designer.cs 2 视图(View)2.1 ViewServer2.1.…...
大语言模型的多垂类快速评估与 A/B 测试
简介 行业领先的模型构建企业携手澳鹏(Appen)开展了一项极具挑战性的项目。针对 3 至 6 个大型语言模型(LLM),在广泛的通用领域及复杂专业领域(如医疗保健、法律、金融、编程、数学和汽车行业等࿰…...
一个成功的Git分支模型
本作品原发布账号为【白鸽子中文网】,现转至当前账号【飞翔中文网】。 反思备录(2020/3/5) 这个模型构思于2010年,现已过去10余年,(2010年)那时正处于Git诞生后不久。在这10年间,git-flow(本文中提到的分支模型) 在许多软件队伍里…...
MySQL 在 CentOS 7 上安装的步骤指南
🏝️专栏:Mysql_猫咪-9527的博客-CSDN博客 🌅主页:猫咪-9527-CSDN博客 “欲穷千里目,更上一层楼。会当凌绝顶,一览众山小。” 目录 1. 卸载不需要的环境 2. 获取 MySQL YUM 仓库 3. 安装 MySQL 4. 启动…...
DeepSeek-R1深度解读
deepseek提出了一种通过强化学习(RL)激励大语言模型(LLMs)推理能力的方法,个人认为最让人兴奋的点是:通过RL发现了一个叫“Aha Moment”的现象,这个时刻发生在模型的中间版本中。在这个阶段&…...
吴恩达机器学习笔记复盘(六)梯度下降算法
简介 梯度下降(Gradient Descent)是一种常用的优化算法,广泛应用于机器学习、深度学习等领域,在这里是用于求J(w,b)局部最小值。 我自己觉得这样说有点过于抽象。换个直观点的说法就是,一个人…...
【环境配置】windows下vscode下无法激活conda环境、创建虚拟环境报错
前言 我的本地的系统,绝大部分是使用的ubuntu。去年下半年开始切换成windows,然后windows下使用vscode还需要注意一些小的配置。为了避免反复搜索,这里记录下。 当已经在 windows 下安装了anaconda、vscode,之后的使用有可能存…...
【Linux笔记】动态库与静态库的理解与加载
🔥个人主页🔥:孤寂大仙V 🌈收录专栏🌈:Linux 🌹往期回顾🌹:【Linux笔记】动态库与静态库的制作 🔖流水不争,争的是滔滔不 一、ELF文件二、ELF的形…...
ollama docker设置模型常驻显存
参考: https://github.com/ollama/ollama/issues/5272 https://deepseek.csdn.net/67cfd7c93b685529b708fdee.html 通过-e传入环境变量,ollama运行: docker run -d --gpusall -e OLLAMA_KEEP_ALIVE-1 -v ollama:/root/.ollama -p 11434:114…...
SAP-ABAP:SAP 主数据管理体系深度解析与学习路径介绍
Ⅰ. 主数据体系全景认知 1.1 主数据核心定位 #mermaid-svg-Lf3tZAfcROs5hlN4 {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-Lf3tZAfcROs5hlN4 .error-icon{fill:#552222;}#mermaid-svg-Lf3tZAfcROs5hlN4 .error-t…...