Spring3 MVC中使用Swagger生成API文档

简介: Spring3 MVC中使用Swagger生成API文档

Spring3 MVC中使用Swagger生成API文档


一:Swagger介绍


Swagger是当前最好用的Restful API文档生成的开源项目,通过swagger-spring项目


实现了与SpingMVC框架的无缝集成功能,方便生成spring restful风格的接口文档,


同时swagger-ui还可以测试spring restful风格的接口功能。其官方网站为:


http://swagger.io/


二:Swagger集成Spring3 MVC步骤


Swagger集成springMVC步骤大致只有如下几步:


1.在pom.xml文件中添加swagger相关的依赖

                <!-- swagger API document -->
    <dependency>
      <groupId>com.mangofactory</groupId>
      <artifactId>swagger-springmvc</artifactId>
      <version>0.6.5</version>
    </dependency>

2.创建classpath路径下创建一个swagger.properties, 添加如下内容:


documentation.services.version=1.0


documentation.services.basePath=http://localhost:8080/yourcontextpath


3.在springMVC的main-servlet.xml文件添加如下配置

  <context:property-placeholder location="classpath:swagger.properties" />
  <bean id="documentationConfig" class="com.mangofactory.swagger.configuration.DocumentationConfig" />

4.重新打包部署你的项目到WEB服务器,访问地址


http://localhost:8080/your-contextpath /api-docs即可看到注解生成的API说明


三:常见swagger注解一览与使用


APIs.@Api


@ApiClass


@ApiError


@ApiErrors


@ApiOperation


@ApiParam


@ApiParamImplicit


@ApiParamsImplicit


@ApiProperty


@ApiResponse


@ApiResponses


@ApiModel


在代码中使用例子:

import java.util.HashMap;
import java.util.Map;
 
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;
 
import com.wordnik.swagger.annotations.ApiOperation;
 
@Controller
@RequestMapping("/api/swagger")
public class SwaggerDemoController {
  private static final Logger logger = LoggerFactory.getLogger(SwaggerDemoController.class);
  
  @ApiOperation(value = "query api basic information")
  @RequestMapping(value = "/info", method = RequestMethod.GET)
  @ResponseBody
  public Map<String, String> queryAPIInfo() {
    logger.info("查询更新新版本号");
    Map<String, String> map = new HashMap<String, String>();
    map.put("language", "Java");
    map.put("format", "JSON");
    map.put("tools", "swagger");
    map.put("version", "1.0");
    return map;
  }
  
  @ApiOperation(value = "query data with parameters")
  @RequestMapping(value = "/data", method = RequestMethod.GET)
  @ResponseBody
  public Map<String, String> queryData(@RequestParam String words) {
    logger.info("查询更新新版本号");
    Map<String, String> map = new HashMap<String, String>();
    map.put("keyword", words);
    map.put("data", "this is demo data");
    return map;
  }
}

四:运行swagger-ui测试接口


下载swagger-ui的最新版本到本地,改名为swagger-ui,把dist下面的部署到tomcat


或者任何WEB服务器上,启动后访问如下地址: http://localhost:8080/swagger-ui


注意把swagger-ui中的index.html中的http://petstore.swagger.io/v2/swagger.json改为


http://localhost:8080/your-contextpath /api-docs保存,然后在启动WEB服务器,

显示如下:

展开输入参数以后,点击【try it out】即可测试接口,查看返回数据。

注意:加上之后启动报Bean not found mapping之类的错误,请在对应

xml文件中加上如下的配置:

<context:annotation-config />
<mvc:default-servlet-handler />

相关文章
|
8月前
|
人工智能 安全 架构师
告别旅行规划的"需求文档地狱"!这个AI提示词库,让你像调API一样定制完美旅程
作为开发者,旅行规划如同“需求地狱”:信息碎片、需求多变、缺乏测试。本文提出一套“企业级”AI提示词库,将模糊需求转化为结构化“API请求”,实现标准化输入输出,让AI成为你的专属旅行架构师,30分钟生成专业定制方案,提升决策质量,降低90%时间成本。
816 129
|
7月前
|
JSON API 数据格式
小红书API接口文档:笔记详情数据开发手册
小红书笔记详情API可获取指定笔记的标题、正文、互动数据及多媒体资源,支持字段筛选与评论加载。通过note_id和access_token发起GET/POST请求,配合签名验证,广泛用于内容分析与营销优化。
1373 3
|
8月前
|
XML Java Nacos
Spring Boot 整合Nacos 版本兼容适配 史上最详细文档
本文介绍SpringBoot整合Nacos的完整流程,涵盖Nacos下载安装、配置中心与服务发现集成、版本兼容性问题及实战配置。重点解决SpringBoot 3.3.0与Nacos版本适配难题,推荐使用Spring Cloud Alibaba方案,并提供项目开源地址供参考学习。
|
数据采集 人工智能 Java
1天消化完Spring全家桶文档!DevDocs:一键深度解析开发文档,自动发现子URL并建立图谱
DevDocs是一款基于智能爬虫技术的开源工具,支持1-5层深度网站结构解析,能将技术文档处理时间从数周缩短至几小时,并提供Markdown/JSON格式输出与AI工具无缝集成。
570 1
1天消化完Spring全家桶文档!DevDocs:一键深度解析开发文档,自动发现子URL并建立图谱
|
7月前
|
前端开发 Java 微服务
《深入理解Spring》:Spring、Spring MVC与Spring Boot的深度解析
Spring Framework是Java生态的基石,提供IoC、AOP等核心功能;Spring MVC基于其构建,实现Web层MVC架构;Spring Boot则通过自动配置和内嵌服务器,极大简化了开发与部署。三者层层演进,Spring Boot并非替代,而是对前者的高效封装与增强,适用于微服务与快速开发,而深入理解Spring Framework有助于更好驾驭整体技术栈。
|
前端开发 Java 测试技术
微服务——SpringBoot使用归纳——Spring Boot中的MVC支持——@RequestParam
本文介绍了 `@RequestParam` 注解的使用方法及其与 `@PathVariable` 的区别。`@RequestParam` 用于从请求中获取参数值(如 GET 请求的 URL 参数或 POST 请求的表单数据),而 `@PathVariable` 用于从 URL 模板中提取参数。文章通过示例代码详细说明了 `@RequestParam` 的常用属性,如 `required` 和 `defaultValue`,并展示了如何用实体类封装大量表单参数以简化处理流程。最后,结合 Postman 测试工具验证了接口的功能。
839 0
微服务——SpringBoot使用归纳——Spring Boot中的MVC支持——@RequestParam
|
存储 JSON API
如何将 Swagger 文档导出为 PDF 文件
你会发现自己可能需要将 Swagger 文档导出为 PDF 或文件,以便于共享和存档。在这篇博文中,我们将指导你完成将 Swagger 文档导出为 PDF 格式的过程。
|
JSON 前端开发 Java
微服务——SpringBoot使用归纳——Spring Boot中的MVC支持——@RequestBody
`@RequestBody` 是 Spring 框架中的注解,用于将 HTTP 请求体中的 JSON 数据自动映射为 Java 对象。例如,前端通过 POST 请求发送包含 `username` 和 `password` 的 JSON 数据,后端可通过带有 `@RequestBody` 注解的方法参数接收并处理。此注解适用于传递复杂对象的场景,简化了数据解析过程。与表单提交不同,它主要用于接收 JSON 格式的实体数据。
1515 0
|
10月前
|
存储 人工智能 自然语言处理
用Spring AI搭建本地RAG系统:让AI成为你的私人文档助手
想让AI帮你读懂PDF文档吗?本文教你用Spring AI和Ollama搭建一个本地RAG系统,让AI成为你的私人文档助手。无需GPU,无需云端API,只需几行代码,你的文档就能开口说话了!
2090 2
|
10月前
|
前端开发 Java API
Spring Cloud Gateway Server Web MVC报错“Unsupported transfer encoding: chunked”解决
本文解析了Spring Cloud Gateway中出现“Unsupported transfer encoding: chunked”错误的原因,指出该问题源于Feign依赖的HTTP客户端与服务端的`chunked`传输编码不兼容,并提供了具体的解决方案。通过规范Feign客户端接口的返回类型,可有效避免该异常,提升系统兼容性与稳定性。
716 0