`
Everyday都不同
  • 浏览: 723675 次
  • 性别: Icon_minigender_1
  • 来自: 宇宙
社区版块
存档分类
最新评论

使用swagger管理接口

阅读更多

简介:Swagger是一种Rest API的 简单但强大的表示方式,标准的,语言无关,这种 表示方式不但人可读,而且机器可读。 可以作为Rest API的交互式文档,也可以作为Rest API的形式化的接口描述,生成客户端和服务端的代码。

 

下面结合比较常见的场景,大概说下在Springboot下如何使用swagger来管理接口,以便前后端开发人员能够很好的做接口的对接,同时也利于接口的后续维护开发。

 

1. maven里引入swagger所需jar包:

<dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>io.springfox</groupId>
            <artifactId>springfox-swagger2</artifactId>
            <version>${swagger2.version}</version>
        </dependency>
        <dependency>
            <groupId>io.springfox</groupId>
            <artifactId>springfox-swagger-ui</artifactId>
            <version>${swagger2.version}</version>
        </dependency>
    </dependencies>

 

2.指定swagger的一些静态资源文件配置,一般用一个类来管理维护:

@Configuration
@EnableSwagger2
public class SwaggerConfiguration extends WebMvcConfigurerAdapter {

    @Value("${swagger2.basePackage:com.xxx}")
    private String swagger2BasePackage;
    @Value("${swagger2.title:系统API文档}")
    private String swagger2Title;
    @Value("${swagger2.api.version:1.0}")
    private String apiVersion;

    @Override
    public void addResourceHandlers(ResourceHandlerRegistry registry) {
        registry.addResourceHandler("swagger-ui.html").addResourceLocations("classpath:/META-INF/resources/");
        registry.addResourceHandler("/webjars*").addResourceLocations("classpath:/META-INF/resources/webjars/");
    }

    @Bean
    public Docket createRestApi() {
        return new Docket(DocumentationType.SWAGGER_2).apiInfo(apiInfo())
                .select().apis(RequestHandlerSelectors.basePackage(swagger2BasePackage))
                .paths(PathSelectors.any()).build();
    }

    private ApiInfo apiInfo() {
        return new ApiInfoBuilder().title(swagger2Title).version(apiVersion).build();
    }
}

 

3. 如何使用?

这一步我会用比较常见的业务场景去描述接口:

首先Controller层(类)上需要这样注解:

@Api(value = "SWAGGER接口")
@RestController
@RequestMapping(value = "/api/swagger/user")
public class SwaggerController{
  //....
}

 

1)请求参数对应一组String字符串或者一个VO,返回结果是单个对象

此时方法一定要有返回而不能是void

eg:根据输入条件查询某条记录

@ApiOperation(value="获取用户详细信息", notes="根据参数来获取用户详细信息")
    @ApiImplicitParams({
        @ApiImplicitParam(name = "id", value = "用户ID", dataType = "Long", paramType = "query"),
        @ApiImplicitParam(name = "name", value = "用户名字", required = true, dataType = "String", paramType = "query"),
        @ApiImplicitParam(name = "age", value = "用户年龄", dataType = "Long", paramType = "query")
    })
    @RequestMapping(value="", method=RequestMethod.GET)
    @PostMapping("/find1")
    public  User find (@ModelAttribute User user) {//@ModelAttribute User user 等效于Long id, String name; Long age;
        return new User();
    }

 其中User类如下:

//@ApiModel(value="User", description="用户对象")
public class User {
  @ApiModelProperty(value = "用户ID", required = true)
    private Long id;
  @ApiModelProperty(hidden = true)
    private String name;
  @ApiModelProperty(value = "用户年龄")
    private Long age;
  public void setId(Long id) {
    this.id = id;
  }
  public void setName(String name) {
    this.name = name;
  }
  public void setAge(Long age) {
    this.age = age;
  }
  public Long getId() {
    return id;
  }
  public String getName() {
    return name;
  }
  public Long getAge() {
    return age;
  }
    
}

 User类是对应查询条件或查询结果组成的实体~,每个属性需要用@ApiModelProperty去描述每个字段的含义;User类上的@ApiModel注解可以选择性给出。

 

访问swagger接口描述页面只需启动项目(这里是springboot),然后输入http://localhost:8080/swagger-ui.html#!即可访问,我们点击对应的Controller和接口,可以看到:



 

Paramters就是描述输入参数的区域,而Response则是输出的描述,Response可以切换到Model,可以看到输出的字段的具体含义:



 

2)请求参数是复合的,这时候必须对应一个实体类,如:

//@ApiModel(value="Params", description="传入参数")
public class Params {
  @ApiModelProperty(name="param1", value = "参数1", required = true)
  private String param1;
  
  @ApiModelProperty(name="input", value = "输入", required = true)
  private List<Input> input;
  
  public String getParam1() {
    return param1;
  }

  public void setParam1(String param1) {
    this.param1 = param1;
  }

  public List<Input> getInput() {
    return input;
  }

  public void setInput(List<Input> input) {
    this.input = input;
  }

}

 

返回是一个集合类型:

@ApiOperation(value="获取用户信息集合", notes="根据输入类型来获取用户信息集合")
    @PostMapping("/find2")
    @ApiResponse(response = User.class, responseContainer="List", code = 200, message = "请求成功")
    public List<User> find2(@ApiParam(value="传入参数类型", required=true) @RequestBody Params params) {
      
      return new ArrayList<User>();
    }

 

ui上点击对应方法,可以看到:



 

 

可以看到,现在无论是对于接口里再复杂的输入和输出,都能比较清楚地看到每个属性(字段)的含义,以及可以在swagger的ui上直接用Try it out 按钮来测试接口的可用性。

 

swagger可以很好地帮助我们管理项目接口~,以及不同业务侧之间的接口对接工作。

  • 大小: 33.4 KB
  • 大小: 9.1 KB
  • 大小: 34.8 KB
  • 大小: 10.6 KB
分享到:
评论

相关推荐

    swagger接口管理框架

    Swagger接口管理框架是一款广泛应用于现代Web服务开发中的工具,它主要负责帮助开发者高效地管理和文档化API接口。Swagger的核心理念是“代码即文档”,通过在代码中添加特定的注解,能够自动生成易于理解和使用的...

    springboot集成swagger实现接口管理源码

    SpringBoot集成Swagger实现接口管理是现代Web开发中的一项重要技术,它使得API文档的创建、维护和使用变得更加方便。Swagger是一款强大的RESTful API文档工具,它允许开发者通过注解来描述Spring MVC的Controller...

    swagger接口文档改良添加左侧菜单.rar

    Swagger接口文档改良添加左侧菜单是针对API开发过程中的一个重要优化,旨在提高开发人员对API文档的使用效率。Swagger是一款流行的RESTful API文档工具,它能够自动生成、描述、测试和发现Web服务接口。通过在...

    Swagger API接口创建

    Swagger是一款RESTful接口文档自动生成与功能测试工具,它能够帮助开发者高效地管理和维护API接口。本文旨在介绍如何在项目中集成Swagger,并解决一些常见的问题。Swagger的核心价值在于其提供了一个标准化且语言...

    swagger静态部分文件打包

    Swagger 是一个广泛使用的 API 设计和开发工具,它允许开发者以 YAML 或 JSON 格式定义 RESTful 风格的 Web 服务接口。这个压缩包文件 "swagger" 可能包含了 Swagger 的静态资源,这些资源主要用于展示和测试 API ...

    Swagger接口导出Word.rar

    本教程将围绕如何使用C#和.NET来通过Swagger将接口导出为Word文档进行详解。 首先,你需要在你的项目中引入Swagger。可以通过NuGet包管理器安装`Swashbuckle.AspNetCore`,这将为你的ASP.NET Web API项目添加...

    swagger 接口文档注释

    总之,Swagger 提供了一种强大的方式来管理和文档化微服务中的接口,通过注释代码实现自动化文档生成,简化了 API 的设计、测试和维护流程。在实践中,确保所有团队成员遵循统一的注释规范,可以极大地提升开发效率...

    一款超强接口管理神器 Apifox教程

    * 使用 Swagger 管理接口文档。 * 使用 Postman 调试接口。 * 使用 RAP 或 Easy Mock 来进行 Mock 数据。 * 使用 JMeter 做接口自动化测试。 但是,这些解决方案存在的问题是: * 维护不同工具之间数据一致性非常...

    .NET_Core2.0_使用swagger调试API接口_log4记录日志_外加上传图片

    Swagger提供了友好的图形界面,帮助我们调试和文档化API接口,而Log4则是广泛使用的日志记录框架,有助于追踪和诊断程序运行时的问题。在这个项目中,我们将探讨如何在ASP.NET Core 2.0应用中集成这两个工具,并实现...

    swagger接口日志生成工具

    Swagger接口日志生成工具是一款专为PHP开发设计的实用辅助工具,它可以帮助开发者方便地记录和管理Swagger定义的API接口的执行情况。Swagger是一个流行的开源框架,用于构建、文档化和交互式RESTful API,而这款日志...

    swaggeruilayer基于swagger的漂亮的接口文档

    Swagger是一个流行的API设计框架,它使用OpenAPI规范来定义RESTful API接口,允许开发者轻松地创建、共享和使用API。Swagger UI Layer是这个生态中的一个重要组件,它的主要作用是对默认的Swagger UI进行增强,提升...

    swagger实现多项目api管理

    在描述中提到的“改造Swagger实现多项目api管理”,实际上可能涉及到编写自定义脚本或使用现有工具(如 Swagger Codegen、Redocly、Stoplight 等)进行集成。文件列表中提到了 `swagger-ui-2.2.10`,这是 Swagger UI...

    Swagger搭建Restful接口.rar

    Swagger是一款强大的工具,专门用于构建、设计和文档化RESTful API。它允许开发者通过注解在代码中描述接口,然后自动生成易于理解的...通过使用Swagger,开发者可以更好地管理RESTful服务,提高API的质量和易用性。

    asp.net core api+jwt+swagger CRM管理系统 后台接口

    总的来说,这个CRM系统结合了ASP.NET Core的强大功能、JWT的安全认证机制以及Swagger的API管理工具,构建了一个高效、安全且易于使用的后台接口。这样的设计不仅提高了开发效率,也提升了系统的可维护性和用户体验。

    Swagger学习例子

    总之,Swagger是一个强大的工具,它可以帮助我们轻松地创建、管理和使用RESTful API。在"Swagger学习例子"中,你将学习如何在C# .NET环境中集成Swagger,创建清晰、详细的API文档,并通过Swagger UI进行交互式测试。...

    swagger2Demo,swagger

    在这个名为"swagger2Demo"的项目中,我们看到作者利用Swagger 2创建了一个演示应用,目的是为了展示如何使用Swagger来调试接口。Swagger 2是Swagger框架的一个升级版本,它提供了更多的功能和改进,使得API开发更加...

    Swagger与Spring结合生成Restful接口文档

    在与Spring框架结合使用时,Swagger能自动生成接口的JSON描述,并通过UI展示成友好的文档,使得开发者和使用者都能方便地理解API的使用方式。 在Spring项目中集成Swagger,首先需要在`pom.xml`文件中引入相关的依赖...

    Web API安装swagger控件,自动生成api接口文档

    - 使用NuGet包管理器或命令行工具,运行以下命令来安装`Swashbuckle.AspNetCore`包: ``` Install-Package Swashbuckle.AspNetCore ``` - 这个包会为你的Web API项目添加Swagger支持,包括Swagger JSON生成器和...

    Asp.Net Core使用swagger生成api文档的完整步骤

    在Asp.Net Core中,Swagger是一个强大的工具,用于生成API文档,它可以帮助开发者轻松地创建、测试和理解API接口。本篇文章将详细讲解如何在Asp.Net Core项目中使用NSwag(包括Swashbuckle)来实现Swagger的集成。 ...

    SpringBoot整合Swagger2并且可以向数据库写入数据

    接着,我们创建一个Controller来处理HTTP请求,并使用Repository接口进行数据库操作: ```java // UserController.java @RestController @RequestMapping("/users") public class UserController { @Autowired ...

Global site tag (gtag.js) - Google Analytics