springBoot集成swagger-的使用(详细教程)

目录

1、引入swagger依赖

2、编辑配置文件

3、对应controller层加上swagger注解

4、定义返回的vo类加上swagger注解-作用为字段注释

5、启动项目访问swagger地址


1、引入swagger依赖

        <dependency>
            <groupId>com.github.xiaoymin</groupId>
            <artifactId>knife4j-spring-boot-starter</artifactId>
            <version>3.0.3</version>
        </dependency>

2、编辑配置文件

package com.jt.config;

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import springfox.documentation.builders.ApiInfoBuilder;
import springfox.documentation.builders.PathSelectors;
import springfox.documentation.builders.RequestHandlerSelectors;
import springfox.documentation.service.Contact;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spring.web.plugins.Docket;
import springfox.documentation.swagger2.annotations.EnableSwagger2;
/**
 * @Author Connor
 * @Date: 2023/07/31/ 14:47
 * @Description
 */
@Configuration
@EnableSwagger2
public class SwaggerConfiguration {

    @Bean(value = "cat")
    public Docket defaultApi2() {

        return new Docket(DocumentationType.OAS_30)
                .apiInfo(new ApiInfoBuilder()
                        .title("这是车辆模块API ")
                        .description("# 车辆模块所有的接口的入参,出参等等信息")
                        .termsOfServiceUrl("http://cat.com")
                        .contact(new Contact("connor","http://cat.com","1275xxx511@qq.com"))
                        .version("1.0")
                        .build())
                //分组名称
                .groupName("车辆模块")
                .select()
                //这里指定Controller扫描包路径
                .apis(RequestHandlerSelectors.basePackage("com.jt.controller.cat"))
                .paths(PathSelectors.any())
                .build();
    }
    @Bean(value = "item")
    public Docket defaultApi3() {

        return new Docket(DocumentationType.OAS_30)
                .apiInfo(new ApiInfoBuilder()
                        .title("这是其他API ")
                        .description("# 车辆模块所有的接口的入参,出参等等信息")
                        .termsOfServiceUrl("http://cat.com")
                        .contact(new Contact("connor","http://cat.com","12756xxx8511@qq.com"))
                        .version("1.0")
                        .build())
                //分组名称
                .groupName("item模块")
                .select()
                //这里指定Controller扫描包路径
                .apis(RequestHandlerSelectors.basePackage("com.jt.controller.item"))
                .paths(PathSelectors.any())
                .build();
    }
}

3、对应controller层加上swagger注解

package com.jt.controller.cat;

import com.jt.pojo.ItemCat;
import com.jt.service.ItemCatService;
import com.jt.vo.SysResult;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;

import java.util.List;

@RestController
@RequestMapping("/itemCat")
@Api(value ="车辆模块",tags = "车辆模块")

public class ItemCatController {

    @Autowired
    private ItemCatService itemCatService;

    /**
     * 请求路径: /itemCat/findItemCatList/{level}
     * 请求类型: get
     * 请求参数: level
     * 返回值: SysResult(List集合)
     */
    @GetMapping("/findItemCatList/{level}")
    @ApiOperation(value = "查询商品分类列表",notes = "根据level查询商品分类列表")
    public SysResult findItemCatList(@PathVariable Integer level){

        List<ItemCat> list = itemCatService.findItemCatList(level);
        return SysResult.success(list);
    }

    /**
     *  - 请求路径: /itemCat/status
     *  - 请求类型: put
     *  - 返回值:   SysResult对象
     */
    @PutMapping("/status/{id}/{status}")
    @ApiOperation("更新车辆")
    public SysResult updateStatus(ItemCat itemCat){

        itemCatService.updateStatus(itemCat);
        return SysResult.success();
    }

    /**
     * 实现商品分类新增
     *  - 请求路径: /itemCat/saveItemCat
     *  - 请求类型: post
     *  - 请求参数:  表单数据
     *  - 返回值结果: SysResult对象
     */
    @PostMapping("/saveItemCat")
    public SysResult saveItemCat(@RequestBody ItemCat itemCat){

        itemCatService.saveItemCat(itemCat);
        return SysResult.success();
    }

    /**
     *  - 请求路径: /itemCat/updateItemCat
     *  - 请求类型: put
     *  - 请求参数:  表单数据 ItemCat对象
     *  - 返回值:  SysResult对象
     */
    @PutMapping("/updateItemCat")
    public SysResult updateItemCat(@RequestBody ItemCat itemCat){

        itemCatService.updateItemCat(itemCat);
        return SysResult.success();
    }

    /**
     * - 请求路径: /itemCat/deleteItemCat?id=xx&level=xx
     *  - 请求类型: delete
     *  - 业务描述: 当删除节点为父级时,应该删除自身和所有的子节点
     *  - 请求参数: id/level
     *  - 返回值:  SysResult对象
     */
    @DeleteMapping("/deleteItemCat")
    public SysResult deleteItemCat(ItemCat itemCat){

        itemCatService.deleteItemCat(itemCat);
        return SysResult.success();
    }


}

4、定义返回的vo类加上swagger注解-作用为字段注释

package com.jt.pojo;
import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data;
import lombok.experimental.Accessors;

import java.util.List;

/**
 * @author connor
 * 时间 2021/3/26
 */
@Data
@Accessors(chain = true)
@TableName("item_cat")
public class ItemCat extends BasePojo{
    @TableId(type = IdType.AUTO)//主键自增
    @ApiModelProperty("定义主键")
    private Integer id;
    @ApiModelProperty("定义父级菜单")
    private Integer parentId;
    @ApiModelProperty("定义父级菜单")
    private String name;
    @ApiModelProperty("分类名称")
    private Boolean status;
    @ApiModelProperty("商品分类等级  1 2 3")//分类状态 0 停用 1 正常
    private Integer level;      //商品分类等级  1 2 3
    @TableField(exist = false)
    private List<ItemCat> children; //是业务数据 不是数据库字段
}

5、启动项目访问swagger地址

启动项目访问http://localhost:8093/doc.html,注意改成自己项目的端口号

到此swagger引入完成,可以愉快的交给前端联调接口了。 

  • 7
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Spring Boot项目中集成Swagger UI非常简单。以下是一些基本的步骤: 1. 添加Swagger依赖:在项目的`pom.xml`文件中添加Swagger的相关依赖。可以使用以下依赖: ```xml <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-boot-starter</artifactId> <version>3.0.0</version> </dependency> ``` 2. 创建Swagger配置类:创建一个Java类,用于配置Swagger。可以使用以下示例代码: ```java import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import springfox.documentation.builders.ApiInfoBuilder; import springfox.documentation.builders.PathSelectors; import springfox.documentation.builders.RequestHandlerSelectors; import springfox.documentation.service.ApiInfo; import springfox.documentation.spi.DocumentationType; import springfox.documentation.spring.web.plugins.Docket; import springfox.documentation.swagger2.annotations.EnableSwagger2; @Configuration @EnableSwagger2 public class SwaggerConfig { @Bean public Docket apiDocket() { return new Docket(DocumentationType.SWAGGER_2) .select() .apis(RequestHandlerSelectors.basePackage("com.example.controller")) .paths(PathSelectors.any()) .build() .apiInfo(apiInfo()); } private ApiInfo apiInfo() { return new ApiInfoBuilder() .title("API Documentation") .description("API Documentation for My Awesome App") .version("1.0.0") .build(); } } ``` 在上述代码中,`@EnableSwagger2`注解启用Swagger,`@Bean`注解创建一个`Docket`实例,配置Swagger的基本信息和扫描的包路径。 3. 启动应用程序:运行Spring Boot应用程序,Swagger UI将在`http://localhost:8080/swagger-ui.html`上自动启动。 现在,您可以在Swagger UI中浏览和测试您的API。Swagger UI将根据您的代码和注释生成API文档,并提供一个交互式的界面,供用户查看和测试API的各个端点和参数。 请注意,上述示例代码中的包路径和其他配置可能需要根据您的项目结构进行调整。此外,还可以通过其他配置选项来自定义Swagger UI的行为和外观。更多详细信息,请参阅SwaggerSpringfox的官方文档。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值