zoukankan      html  css  js  c++  java
  • SpringBoot整合Swagger2详细教程

    1. 简介

      随着前后端分离开发模式越来越流行,编写接口文档变成了开发人员非常头疼的事。而Swagger是一个规范且完整的web框架,用于生成、描述、调用可视化的RESTful风格的在线接口文档,并解决手写文档时编写和更新以及测试的复杂问题。

    2. 示例代码

    • 创建项目
    • 修改pom.xml
    <project xmlns="http://maven.apache.org/POM/4.0.0"
    	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    	xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    	<modelVersion>4.0.0</modelVersion>
    	<groupId>com.c3stones</groupId>
    	<artifactId>spring-boot-swagger2-demo</artifactId>
    	<version>0.0.1-SNAPSHOT</version>
    	<name>spring-boot-swagger2-demo</name>
    	<description>Spring Boot Swagger2 Demo</description>
    
    	<parent>
    		<groupId>org.springframework.boot</groupId>
    		<artifactId>spring-boot-starter-parent</artifactId>
    		<version>2.2.8.RELEASE</version>
    		<relativePath />
    	</parent>
    
    	<dependencies>
    		<dependency>
    			<groupId>io.springfox</groupId>
    			<artifactId>springfox-swagger2</artifactId>
    			<version>2.9.2</version>
    		</dependency>
    		<dependency>
    			<groupId>io.springfox</groupId>
    			<artifactId>springfox-swagger-ui</artifactId>
    			<version>2.9.2</version>
    		</dependency>
    		<dependency>
    			<groupId>org.projectlombok</groupId>
    			<artifactId>lombok</artifactId>
    		</dependency>
    		<dependency>
    			<groupId>org.springframework.boot</groupId>
    			<artifactId>spring-boot-starter-web</artifactId>
    		</dependency>
    		<dependency>
    			<groupId>org.springframework.boot</groupId>
    			<artifactId>spring-boot-starter-test</artifactId>
    			<scope>test</scope>
    		</dependency>
    	</dependencies>
    
    </project>
    
    • 创建Swagger2配置类
    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;
    
    /**
     * Swagger2配置类
     * 
     * @author CL
     *
     */
    @Configuration
    @EnableSwagger2
    public class Swagger2Config {
    
    	/**
    	 * 注入Docket
    	 * 
    	 * @return
    	 */
    	@Bean
    	public Docket docket() {
    		return new Docket(DocumentationType.SWAGGER_2).apiInfo(setApiInfo()).select()
    				.apis(RequestHandlerSelectors.basePackage("com.c3stones.controller")).paths(PathSelectors.any())
    				.build();
    	}
    
    	/**
    	 * 配置在线文档的基本信息
    	 * 
    	 * @return
    	 */
    	private ApiInfo setApiInfo() {
    		return new ApiInfoBuilder().title("SpringBoot整合Swagger2示例")
    				.description("<a href='https://www.cnblogs.com/cao-lei/' target='_blank'>欢迎访问我的博客</a>")
    				.termsOfServiceUrl("https://www.cnblogs.com/cao-lei/").version("V1.0").build();
    	}
    
    }
    
    • 创建实体
    import lombok.AllArgsConstructor;
    import lombok.Data;
    
    /**
     * 用户信息
     * 
     * @author CL
     *
     */
    @Data
    @AllArgsConstructor
    public class User {
    
    	/**
    	 * 用户ID
    	 */
    	private Long id;
    
    	/**
    	 * 用户名称
    	 */
    	private String username;
    
    	/**
    	 * 年龄
    	 */
    	private Integer age;
    
    }
    
    • 创建Controller
    import java.util.ArrayList;
    import java.util.List;
    
    import org.springframework.http.HttpRequest;
    import org.springframework.web.bind.annotation.RequestMapping;
    import org.springframework.web.bind.annotation.RequestMethod;
    import org.springframework.web.bind.annotation.ResponseBody;
    import org.springframework.web.bind.annotation.RestController;
    
    import com.c3stones.entity.User;
    
    import io.swagger.annotations.Api;
    import io.swagger.annotations.ApiImplicitParam;
    import io.swagger.annotations.ApiImplicitParams;
    import io.swagger.annotations.ApiOperation;
    import springfox.documentation.annotations.ApiIgnore;
    
    /**
     * 用户Controller
     * 
     * @author CL
     *
     */
    @Api(tags = "User / 用户信息")
    @RestController
    @RequestMapping(value = "/user")
    public class UserController {
    
    	/**
    	 * 获取用户信息
    	 * 
    	 * @param user 用户信息
    	 * @return
    	 */
    	@RequestMapping(value = "/get", method = RequestMethod.GET)
    	@ResponseBody
    	@ApiOperation(value = "获取用户信息")
    	@ApiImplicitParams({ @ApiImplicitParam(name = "id", value = "用户ID", required = true, type = "Long"),
    			@ApiImplicitParam(name = "username", value = "用户名称", type = "String"),
    			@ApiImplicitParam(name = "age", value = "年龄", type = "Integer") })
    	public User get(User user) {
    		return new User(1L, "C3Stones", 23);
    	}
    
    	/**
    	 * 获取用户列表
    	 * 
    	 * @param user 用户信息
    	 * @return
    	 */
    	@SuppressWarnings("serial")
    	@RequestMapping(value = "/listData", method = { RequestMethod.GET, RequestMethod.POST })
    	@ResponseBody
    	@ApiOperation(value = "获取用户列表")
    	@ApiImplicitParams({ @ApiImplicitParam(name = "id", value = "用户ID", type = "Long"),
    			@ApiImplicitParam(name = "username", value = "用户名称", type = "String"),
    			@ApiImplicitParam(name = "age", value = "年龄", type = "Integer") })
    	public List<User> listData(User user, @ApiIgnore HttpRequest request) {
    		return new ArrayList<User>() {
    			{
    				add(new User(1L, "张三", 23));
    				add(new User(2L, "李四", 24));
    				add(new User(3L, "王五", 25));
    			}
    		};
    	}
    }
    
    • 创建启动类
    import org.springframework.boot.SpringApplication;
    import org.springframework.boot.autoconfigure.SpringBootApplication;
    
    /**
     * 启动类
     * 
     * @author CL
     *
     */
    @SpringBootApplication
    public class Application {
    
    	public static void main(String[] args) {
    		SpringApplication.run(Application.class, args);
    	}
    
    }
    

    3. 测试

    • 启动项目
    • 浏览器访问
    http://127.0.0.1:8080/swagger-ui.html
    

    4. 项目地址

      spring-boot-swagger2-demo

  • 相关阅读:
    prometheus TSDB和外部存储系统
    Prometheus时序数据
    Prometheus简介
    Docker网络
    Ingress
    CRI和多容器运行时
    K8s容器存储接口(CSI)介绍
    EasyNVR视频广场点击视频后切换码流才能播放是什么原因?
    EasyNVR更新H265转H264模块内存增长且显示占用高如何解决?
    EasyNVR拉公网RTSP流失败问题调试和解决
  • 原文地址:https://www.cnblogs.com/cao-lei/p/13410872.html
Copyright © 2011-2022 走看看