SpringBoot集成swagger的实例代码

SpringBoot集成swagger的实例代码,第1张

概述Swagger是一款RESTFUL接口的文档在线自动生成+功能测试功能软件。本文简单介绍了在项目中集成swagger的方法和一些常见问题。如果想深入分析项目源码,了解更多内容,见参考资料。

Swagger 是一款RESTFul接口的文档在线自动生成+功能测试功能软件。本文简单介绍了在项目中集成swagger的方法和一些常见问题。如果想深入分析项目源码,了解更多内容,见参考资料。

Swagger 是一个规范和完整的框架,用于生成、描述、调用和可视化 RESTful 风格的 Web 服务。总体目标是使客户端和文件系统作为服务器以同样的速度来更新。文件的方法,参数和模型紧密集成到服务器端的代码,允许API来始终保持同步。Swagger 让部署管理和使用功能强大的API从未如此简单。

对于搬砖的同学来说,写接口容易,写接口文档很烦,接口变动,维护接口文档就更更更烦,所以经常能发现文档与程序不匹配。

等过一段时间就连开发者也蒙圈了

Swagger2快速方便的解决了以上问题。一个能与Spring MVC程序配合组织出强大RESTful api文档的新宠儿。

下面直接上代码

pom.xml

<?xml version="1.0" enCoding="UTF-8"?><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 http://maven.apache.org/xsd/maven-4.0.0.xsd">  <modelVersion>4.0.0</modelVersion>  <groupID>com.zhongxin.wealth</groupID>  <artifactID>wealthweb</artifactID>  <version>0.0.1-SNAPSHOT</version>  <packaging>jar</packaging>  <name>wealthweb</name>  <description>Demo project for Spring Boot</description>  <parent>    <groupID>org.springframework.boot</groupID>    <artifactID>spring-boot-starter-parent</artifactID>    <version>1.5.9.RELEASE</version>    <relativePath/> <!-- lookup parent from repository -->  </parent>  <propertIEs>    <project.build.sourceEnCoding>UTF-8</project.build.sourceEnCoding>    <project.reporting.outputEnCoding>UTF-8</project.reporting.outputEnCoding>    <java.version>1.8</java.version>  </propertIEs>  <dependencIEs>    <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>    <dependency>      <groupID>io.springfox</groupID>      <artifactID>springfox-swagger2</artifactID>      <version>2.7.0</version>    </dependency>    <dependency>      <groupID>io.springfox</groupID>      <artifactID>springfox-swagger-ui</artifactID>      <version>2.7.0</version>    </dependency>  </dependencIEs></project>

  创建配置类

package com.zhongxin.wealth.APIConfig;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;/** * Created by DingYS on 2017/12/8. */@Configuration@EnableSwagger2public class Swagger2 {  @Bean  public Docket createRestAPI() {    return new Docket(documentationType.SWAGGER_2)        .APIInfo(APIInfo())        .select()        .APIs(RequestHandlerSelectors.basePackage("com.zhongxin.wealth.web"))        .paths(PathSelectors.any())        .build();  }  private APIInfo APIInfo() {    return new APIInfoBuilder()        .Title("廊坊委贷大数据统计结果输出接口")        .version("1.0")        .build();  }}

  controller编写

package com.zhongxin.wealth.web;import io.swagger.annotations.APIOperation;import org.springframework.web.bind.annotation.RequestMapPing;import org.springframework.web.bind.annotation.RequestMethod;import org.springframework.web.bind.annotation.RestController;/** * Created by DingYS on 2017/12/7. */@RestController@RequestMapPing("/hello")public class HelloWordController {  @APIOperation(value="测试接口",notes="这只是一个测试controller调用的接口,没有任何的业务逻辑")  @RequestMapPing(value = {"/test"},method = RequestMethod.GET)  public String testHello(){    return "hello";  }}

  代码完成,准备看效果

点击Try it out!

是不是很详细,很高大上。

注:集成过程中刚开始用的swagger2.2.2版本,会在首页出现一个error的错误提醒

{“schemaValIDationMessages”:[{“level”:”error”,”message”:”Can't read from file http://127.0.0.1:8888/v2/API-docs"}]}

  但是浏览器访问:http://127.0.0.1:8888/v2/api-docs 又能获取 结果

{“swagger”:”2.0”,”info”:{“version”:”1.0”,”Title”:”廊坊委贷大数据统计结果输出接口”,”contact”:{},”license”:{}},”host”:”127.0.0.1:8888”,”basePath”:”/“,”Tags”:[{“name”:”hello-word-controller”,”description”:”Hello Word Controller”}],”paths”:{“/hello/test”:{“get”:{“Tags”:[“hello-word-controller”],”summary”:”测试接口”,”description”:”这只是一个测试controller调用的接口,没有任何的业务逻辑”,”operationID”:”testHelloUsingGET”,”consumes”:[“application/Json”],”produces”:[“/“],”responses”:{“200”:{“description”:”OK”,”schema”:{“type”:”string”}},”401”:{“description”:”Unauthorized”},”403”:{“description”:”ForbIDden”},”404”:{“description”:”Not Found”}}}}}}

  具体原因本人不明,换成2.7.0版本以后没在出现。

总结

以上所述是小编给大家介绍的SpringBoot集成swagger的实例代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对编程小技巧网站的支持!

总结

以上是内存溢出为你收集整理的SpringBoot集成swagger的实例代码全部内容,希望文章能够帮你解决SpringBoot集成swagger的实例代码所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1227370.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-05
下一篇 2022-06-05

发表评论

登录后才能评论

评论列表(0条)

保存