使用Knife4j做API文档,效果更好

Knife4j是一个集Swagger2 和 OpenAPI3 为一体的增强解决方案。

快速开始(Spring Boot 2 + OpenAPI2)

第一步:创建Spring Boot项目并且在pom.xml中引入Knife4j的依赖包,代码如下:

<!--引入Knife4j的官方start包,该指南选择Spring Boot版本<3.0,开发者需要注意-->
<dependency>
    <groupId>com.github.xiaoymin</groupId>
    <artifactId>knife4j-openapi2-spring-boot-starter</artifactId>
    <version>4.4.0</version>
</dependency>

第二步:创建Swagger配置依赖,代码如下::

@Configuration
@EnableSwagger2WebMvc
@Profile({"dev", "test"})
public class Knife4jConfiguration {

     @Bean
    public Docket api() {
        return new Docket(DocumentationType.SWAGGER_2)
                // 指定认证相关信息
                .securitySchemes(Collections.singletonList(apiKey()))
                .select()
                // 指定扫描的包路径
                .apis(RequestHandlerSelectors.basePackage("com.google.controller"))
                .paths(PathSelectors.any())
                .build()
                // 指定路径前缀
                .pathMapping(pathMapping())
                .apiInfo(apiInfo());
    }

    private String pathMapping() {
        if (EnvUtil.isDevEnv() || !OSUtil.isBigoServer()) {
            return "/";
        }
        return "/xxx-xxxx";
    }

    private ApiKey apiKey() {
        return new ApiKey("Token", "Token", "header");
    }

    private ApiInfo apiInfo() {
        return new ApiInfoBuilder().title("官网API")
                .description("官网API.")
                .version("1.0.0")
                .contact(new Contact("Your Name", "https://example.com", "your-email@example.com"))
                .build();
    }
}

第三步:新建一个接口Controller类,如下:

@Api(tags = "首页模块")
@RestController
public class IndexController {

    @ApiImplicitParam(name = "name",value = "姓名",required = true)
    @ApiOperation(value = "向客人问好")
    @GetMapping("/sayHi")
    public ResponseEntity<String> sayHi(@RequestParam(value = "name")String name){
        return ResponseEntity.ok("Hi:"+name);
    }
}

万事俱备,启动Spring Boot项目,浏览器访问Knife4j的文档地址即可查看效果http://localhost:8080/doc.html

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值