【一】springboot整合swagger

简介: 【一】springboot整合swagger
介绍:接下来我会把学习阶段学到的框架等知识点进行整合,每一次整合是在前一章的基础上进行的,所以后面的整合不会重复放前面的代码。每次的demo我放在结尾。

第一步:创建Springboot项目

       打开idea——>点击文件,创建文件。

       选择Spring Initializr,点击下一步。

       选择java版本8,点击下一步。

       根据需要导入依赖,后期可以再按需添加。 点击完成,创建完成Springboot项目。


第二步:导入依赖

<dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
 
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
 
        <!--swagger        -->
        <dependency>
            <groupId>io.springfox</groupId>
            <artifactId>springfox-swagger2</artifactId>
            <version>2.9.2</version>
        </dependency>
        <!--swagger-ui.html模式        -->
        <dependency>
            <groupId>io.springfox</groupId>
            <artifactId>springfox-swagger-ui</artifactId>
            <version>2.9.2</version>
        </dependency>
        <!--doc.html模式        -->
        <dependency>
            <groupId>com.github.xiaoymin</groupId>
            <artifactId>swagger-bootstrap-ui</artifactId>
            <version>1.9.2</version>
        </dependency>
    </dependencies>

       PS:swagger的访问地址有两种样式,此处将两种样式的依赖都进行了导入,样式如下图:

按需索取。


第三步:修改文件

       将配置文件改成yml文件,设置端口号,如图:

       修改启动类,加上@EnableSwagger2注解,目的是开启默认配置的swagger,后期(下一章)会讲到如何自定义swagger配置并开启,如图:


第四步:创建文件

       创建目录结构如图:

        下面展示每一个文件,按需自取。

Controller:

@Api(tags = "产品接口")
@RestController
@RequestMapping("/productController")
public class ProductController {
 
    @ApiOperation(value = "获取产品详情信息")
    @GetMapping("/getProductDetail")
    @ApiImplicitParam(name = "pid", value = "产品id", paramType = "String")
    public BaseResponse<ProductDetailBO> getProductDetail(@RequestParam(value = "pid") String pid) {
        return RespGenerator.returnOK("成功");
    }
 
    @ApiOperation(value = "获取产品列表信息")
    @PostMapping("/getProductList")
    public BaseResponse<List<ProductDetailBO>> getProductList() {
        return RespGenerator.returnOK("成功");
    }
 
    @ApiOperation(value = "删除产品")
    @PostMapping("/deleteProductList")
    public BaseResponse<Integer> deleteProductList(@RequestBody DeleteProductVO deleteProductVO) {
        return RespGenerator.returnOK("成功");
    }
 
}
@Api(tags = "用户接口")
@RestController
@RequestMapping("userController")
public class UserController {
 
    @ApiOperation(value = "修改用户信息")
    @PostMapping("/updateUserMessage")
    public BaseResponse<Integer> updateUserMessage(@RequestBody UpdateUserVO updateUserVO) {
        return RespGenerator.returnOK("成功");
    }
 
    @ApiOperation(value = "获取用户列表信息")
    @PostMapping("/getUserList")
    public BaseResponse<List<UserDetailBO>> getUserList() {
        return RespGenerator.returnOK("成功");
    }
 
    @ApiOperation(value = "删除用户信息")
    @PostMapping("/deleteUser")
    public BaseResponse<Integer> deleteUser(@RequestBody DeleteUserVO deleteUserVO) {
        return RespGenerator.returnOK("成功");
    }
 
}

Api注解:定义接口名称

ApiOperation注解:定义方法名称

ApiImplicitParam注解:定义param参数的各个属性

BO(传出参数):

@Data
@ApiModel("产品详情BO类")
public class ProductDetailBO implements Serializable {
 
    /**
     * 序列化
     */
    private static final long serialVersionUID = 8073662434406951441L;
 
    @ApiModelProperty(value = "产品ID")
    private String pid;
 
    @ApiModelProperty(value = "产品名称")
    private String productName;
 
    @ApiModelProperty(value = "价格")
    private String price;
 
}
@Data
@ApiModel("用户详情BO类")
public class UserDetailBO implements Serializable {
 
    /**
     * 序列化
     */
    private static final long serialVersionUID = 8073662434406951441L;
 
    @ApiModelProperty(value = "用户ID")
    private String uid;
 
    @ApiModelProperty(value = "用户姓名")
    private String userName;
 
    @ApiModelProperty(value = "用户密码")
    private String password;
 
}

ApiModel注解:定义对象名称

ApiModelProperty注解:定义参数名称

实体类:

@Data
public class Product {
 
    private String pid;
 
    private String productName;
 
    private String price;
 
}
@Data
public class User {
 
    private String uid;
 
    private String userName;
 
    private String password;
 
}

VO:

@Data
@ApiModel("删除产品传入VO类")
public class DeleteProductVO implements Serializable {
 
    /**
     * 序列化
     */
    private static final long serialVersionUID = 8073662434406951441L;
 
    @ApiModelProperty(value = "产品ID集合")
    private List<String> pids;
 
}
@Data
@ApiModel("删除用户传入VO类")
public class DeleteUserVO implements Serializable {
 
    /**
     * 序列化
     */
    private static final long serialVersionUID = 8073662434406951441L;
 
    @ApiModelProperty(value = "用户ID集合")
    private List<String> uids;
 
}
@Data
@ApiModel("修改用户信息传入VO类")
public class UpdateUserVO implements Serializable {
 
    /**
     * 序列化
     */
    private static final long serialVersionUID = 8073662434406951441L;
 
    @ApiModelProperty(value = "用户ID")
    private String uid;
 
    @ApiModelProperty(value = "用户密码")
    private String password;
 
}

响应类:

@Data
public class BaseResponse<T> {
  private String code;
  private String message;
  private T data;
 
  /**
   * 
   * 默认构造方法
   * 
   * @param code
   *            状态码
   * @param message
   *            接口信息
   * @param data
   *            接口数据
   */
  public BaseResponse(String code, String message, T data) {
    super();
    this.code = code;
    this.message = message;
    this.data = data;
  }
 
  /**
   * 默认构造方法
   */
  public BaseResponse() {
    super();
  }
 
}

统一返回类:

public class RespGenerator {
  /**
   * 接口调用成功时出参
   * 
   * @param data
   *            接口返回数据
   * @return
   */
  @SuppressWarnings({ "unchecked", "rawtypes" })
  public static BaseResponse returnOK(Object data) {
    return new BaseResponse("200", "接口调用成功!", data);
  }
 
  /**
   * 调用失败
   * 
   * @param code
   *            错误码
   * @param message
   *            错误信息
   * @return
   */
  public static BaseResponse<Object> returnError(String code, String message) {
    return new BaseResponse<Object>(code, message, null);
  }
 
  /**
   * 调用失败
   * 
   * @param message
   *            错误信息
   * @return
   */
  public static BaseResponse<Object> returnError(String message) {
    return new BaseResponse<Object>("-1", message, null);
  }
 
}

       到此完毕,接下来会继续更新加强整合,尽情期待。

       访问地址:http://localhost:8082/swagger-ui.html或者http://localhost:8082/doc.html 

目录
相关文章
|
8月前
|
JSON Java API
微服务——SpringBoot使用归纳——Spring Boot集成 Swagger2 展现在线接口文档——Swagger2 的使用
本文详细介绍了Swagger2的使用方法,包括在Spring Boot项目中的配置与应用。重点讲解了Swagger2中常用的注解,如实体类上的`@ApiModel`和`@ApiModelProperty`,Controller类上的`@Api`、`@ApiOperation`以及参数上的`@ApiParam`等。通过示例代码展示了如何为实体类和接口添加注解,并在页面上生成在线接口文档,实现接口测试。最后总结了Swagger的优势及其在项目开发中的重要性,提供了课程源代码下载链接供学习参考。
639 0
微服务——SpringBoot使用归纳——Spring Boot集成 Swagger2 展现在线接口文档——Swagger2 的使用
|
8月前
|
缓存 Java API
微服务——SpringBoot使用归纳——Spring Boot集成 Swagger2 展现在线接口文档——Swagger2 的配置
本文介绍了在Spring Boot中配置Swagger2的方法。通过创建一个配置类,添加`@Configuration`和`@EnableSwagger2`注解,使用Docket对象定义API文档的详细信息,包括标题、描述、版本和包路径等。配置完成后,访问`localhost:8080/swagger-ui.html`即可查看接口文档。文中还提示了可能因浏览器缓存导致的问题及解决方法。
1004 0
微服务——SpringBoot使用归纳——Spring Boot集成 Swagger2 展现在线接口文档——Swagger2 的配置
|
8月前
|
Java Maven 微服务
微服务——SpringBoot使用归纳——Spring Boot集成 Swagger2 展现在线接口文档——Swagger2 的 maven 依赖
在项目中使用Swagger2工具时,需导入Maven依赖。尽管官方最高版本为2.8.0,但其展示效果不够理想且稳定性欠佳。实际开发中常用2.2.2版本,因其稳定且界面友好。以下是围绕2.2.2版本的Maven依赖配置,包括`springfox-swagger2`和`springfox-swagger-ui`两个模块。
339 0
|
8月前
|
前端开发 Java API
微服务——SpringBoot使用归纳——Spring Boot集成 Swagger2 展现在线接口文档—— Swagger 简介
第6课介绍了在Spring Boot中集成Swagger2以展示在线接口文档的方法。随着前后端分离架构的发展,API文档成为连接前端与后端开发的重要纽带。然而,代码更新频繁导致文档难以同步维护,Swagger2解决了这一问题。通过Swagger,在线API文档不仅方便了接口调用方查看和测试,还支持开发者实时测试接口数据。本文使用Swagger 2.2.2版本,讲解如何在Spring Boot项目中导入并配置Swagger2工具,从而高效管理接口文档。
300 0
|
12月前
|
Java 测试技术 API
详解Swagger:Spring Boot中的API文档生成与测试工具
详解Swagger:Spring Boot中的API文档生成与测试工具
887 4
|
SQL JSON Java
mybatis使用三:springboot整合mybatis,使用PageHelper 进行分页操作,并整合swagger2。使用正规的开发模式:定义统一的数据返回格式和请求模块
这篇文章介绍了如何在Spring Boot项目中整合MyBatis和PageHelper进行分页操作,并且集成Swagger2来生成API文档,同时定义了统一的数据返回格式和请求模块。
514 1
mybatis使用三:springboot整合mybatis,使用PageHelper 进行分页操作,并整合swagger2。使用正规的开发模式:定义统一的数据返回格式和请求模块
|
前端开发 Java 程序员
springboot 学习十五:Spring Boot 优雅的集成Swagger2、Knife4j
这篇文章是关于如何在Spring Boot项目中集成Swagger2和Knife4j来生成和美化API接口文档的详细教程。
2050 1
|
数据可视化 Java API
Spring Boot与Swagger的集成
Spring Boot与Swagger的集成
|
Java API 开发者
在Spring Boot中集成Swagger API文档
在Spring Boot中集成Swagger API文档
|
前端开发 Java Spring
【非降版本解决】高版本Spring boot Swagger 报错解决方案
【非降版本解决】高版本Spring boot Swagger 报错解决方案
957 3

热门文章

最新文章

下一篇
oss云网关配置