`

Spring Boot + Swagger

 
阅读更多

http://springfox.github.io/springfox/docs/current/#customizing-the-swagger-endpoints

一、什么是Swagger?

Swagger:  一个描述Restful service规范

               可以在界面上测试RestfulService

  1. swagger-ui: 用来显示API文档
  2. swagger-editor: 就是一个在线编辑文档说明文件(swagger.json或swagger.yaml文件)的工具,以方便生态中的其他小工具(swagger-ui)等使用
  3. swagger-validator: 这个小工具是用来校验生成的文档说明文件是否符合语法规定的。用法非常简单,只需url地址栏,根路径下加上一个参数url,参数内容是放swagger说明文件的地址。即可校验。
  4. swagger-codegen: 代码生成器,脚手架。可以根据swagger.json或者swagger.yml文件生成指定的计算机语言指定框架的代码。

 

二、Swagger 和 Springfox-Swagger

What is the relationship between swagger-ui and springfox-swagger-ui?
    Swagger Spec is a specification.
    Swagger Api - an implementation of that specification that supports jax-rs, restlet, jersey etc.
    Springfox libraries in general - another implementation of the specification focused on the spring based ecosystem.
    Swagger.js and Swagger-ui - are client libraries in javascript that can consume swagger specification.
    springfox-swagger-ui - the one that you’re referring to, is just packaging swagger-ui in a convenient way so that spring services can serve it up.

翻译下来就是:
swagger-ui 和 springfox-swagger-ui 的关系是?
    Swagger Spec 是一个规范。
    Swagger Api 是 Swagger Spec 规范 的一个实现,它支持 jax-rs, restlet, jersey 等等。
    Springfox libraries 是 Swagger Spec 规范 的另一个实现,专注于 spring 生态系统。
    Swagger.js and Swagger-ui 是 javascript 的客户端库,能消费该规范。
    springfox-swagger-ui 仅仅是以一种方便的方式封装了 swagger-ui ,就是可以显示文档内容

 

三、Springboot 与Swagger集成

1. 增加下面maven 引用

	<dependency>
			<groupId>io.springfox</groupId>
			<artifactId>springfox-swagger2</artifactId>
			<version>2.6.1</version>
		</dependency>

		<dependency>
			<groupId>io.springfox</groupId>
			<artifactId>springfox-swagger-ui</artifactId>
			<version>2.6.1</version>
		</dependency>

 

2. 增加一个Swaagger configuration

 

package com.example.config;

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurerAdapter;

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;


@Configuration
public class Swagger2UiConfiguration extends WebMvcConfigurerAdapter 
{
		@Bean
		public Docket createRestApi() {
			return new Docket(DocumentationType.SWAGGER_2)
					.apiInfo(apiInfo())
					.select()
					.apis(RequestHandlerSelectors.basePackage("org.springframework.boot"))
					.paths(PathSelectors.any())
					.build();
		}
		
		private ApiInfo apiInfo() {
			return new ApiInfoBuilder()
					.title("springboot利用swagger构建api文档")
					.description("简单优雅的restful风格,http://XX")
					.termsOfServiceUrl("http://XXx")
					.version("1.0")
					.build();
		}
	}

 3.Spring Boots Application 类增加 @EnableSwagger2

 

 

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

import springfox.documentation.swagger2.annotations.EnableSwagger2;

@SpringBootApplication
@EnableSwagger2
public class UserApplication1 {

	public static void main(String[] args) {
		
		SpringApplication.run(UserApplication1.class, args);
	}
}

 4. 在Controller 中增加相对应的API注释

package com.example.demo;

import java.util.concurrent.atomic.AtomicLong;

import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;

import io.swagger.annotations.ApiImplicitParam;
import io.swagger.annotations.ApiOperation;


@RestController
public class GreetingController {
	private static final String template = "Hello, %s!";
	private final AtomicLong counter = new AtomicLong();

	@ApiOperation(value="获取Greeting info", notes="根据name获取greeting info")
	@ApiImplicitParam(name = "name", value = "用户名", required = true, dataType = "String", paramType = "path")
	@RequestMapping("/greeting")
	public Greeting greeting(@RequestParam(value = "name", defaultValue = "World") String name) {
		return new Greeting(counter.incrementAndGet(), String.format(template, name));
	}
}

 部署启动服务器

访问: http://localhost:8080/swagger-ui.html#

 

四、Swagger注解

 

swagger通过注解表明该接口会生成文档,包括接口名、请求方法、参数、返回信息的等等。

 

  • @Api:修饰整个类,描述Controller的作用
  • @ApiOperation:描述一个类的一个方法,或者说一个接口
  • @ApiParam:单个参数描述
  • @ApiModel:用对象来接收参数
  • @ApiProperty:用对象接收参数时,描述对象的一个字段
  • @ApiResponse:HTTP响应其中1个描述
  • @ApiResponses:HTTP响应整体描述
  • @ApiIgnore:使用该注解忽略这个API
  • @ApiError :发生错误返回的信息
  • @ApiImplicitParam:一个请求参数
  • @ApiImplicitParams:多个请求参数
分享到:
评论

相关推荐

    Spring boot+swagger(demo)

    在这个"Spring boot+swagger(demo)"项目中,我们主要探讨的是如何将Swagger与Spring Boot结合,以便于快速开发和测试API。下面我们将深入探讨这两个技术以及它们的集成。 1. **Spring Boot**: Spring Boot的核心...

    springboot+myabtis+maven+swagger

    1. **Spring Boot**: Spring Boot是Spring框架的一个扩展,旨在简化Spring应用的初始搭建以及开发过程。它内置了Tomcat服务器,可以快速创建独立运行的Java应用。Spring Boot通过“约定优于配置”的原则,减少了大量...

    从零搭建一个 Spring Boot 开发环境!Spring Boot+Mybatis+Swagger2 环境搭建.docx

    从零搭建一个 Spring Boot 开发环境!Spring Boot+Mybatis+Swagger2 环境搭建

    boot+swagger2.rar

    "boot+swagger2.rar"这个压缩包文件很显然包含了一个使用Spring Boot集成Swagger2的示例项目。Swagger2是OpenAPI Specification(OAS)的一个实现,该规范定义了一种标准格式来描述RESTful API,使得开发者能够轻松...

    Spring boot+Mybatis+Mysql+Swagger+filter与intercepter整合

    Spring boot+Mybatis+Mysql+Swagger整合,包括spring boot下创建过滤器filter与intercepter拦截器,使用Intellij idea创建工程,测试OK

    java springboot+swagger+mysql 框架案例,数据库mysql 5.7

    spring boot + swagger2集成api接口文档,springBoot+swagger+mysql 搭建的一个项目。可以启动。可供参考使用; Swagger是一个规范和完整的框架,用于生成、描述、调用和可视化 RESTful 风格的 Web 服务。总体目标是...

    springboot+shiro+swagger2前后端分离整合

    在Spring Boot中集成Swagger2,可以方便地生成API文档,允许开发者直观地理解接口定义,从而提高开发效率和协同工作能力。 4. **前后端分离**: 前后端分离是现代Web开发的一种架构模式,其中前端和后端通过API...

    Springboot+SpringSecurity+SpringSession+Redis+Mybatis-Plus+Swwager.zip

    本项目“Springboot+SpringSecurity+SpringSession+Redis+Mybatis-Plus+Swwager”整合了Spring Boot、Spring Security、Spring Session、Redis、Mybatis-Plus以及Swagger等技术,旨在构建一个强大的、安全的、具有...

    springboot基本框架+Swagger2

    springboot框架+Swagger2Api接口文档生成工具,里面有2个查询示例。 运行项目后,http://localhost:8080/doc.html或者http://localhost:8080/swagger-ui.html,推荐使用第一个。第一个比较直观。数据库自己建立一下...

    spring boot 2.6.11+springcloud Swagger3构建微服务项目源码

    在本项目中,我们主要关注的是使用Spring Boot 2.6.11、Spring Cloud以及Swagger3构建微服务架构的过程。这些技术都是现代云应用开发中的核心组件,它们各自提供了强大的功能来简化开发和增强应用的可维护性。 首先...

    Spring boot+vue3+element plus实现后台管理系统

    前后端分离项目,Spring boot作为后端,vue框架实现前端,后端整合swagger3测试工具,jwt实现验证码生成,awt生成图形验证码,整合邮箱验证,使用mybatis-generator自动生成实体类以及mapper,设置有拦截器验证登录...

    Spring+swagger示例

    Swagger 提供了一种直观的方式来文档化和测试API,而Spring Boot则是一个快速开发框架,简化了Spring应用的配置和启动过程。本示例将详细介绍如何在Spring Boot项目中整合Swagger,创建一个简单但功能齐全的API文档...

    java代码springboot+Swagger+redis+mybatis+restful代码案例(有文档)

    java代码springboot+Swagger+redis+mybatis+restful代码案例(有文档),写了三个版本的代码,都是简单的代码案例,有数据库设计,完成了表的增删改,关键是这几个技术都有锻炼到位,里面有三个案例,都是不同实现的,...

    Spring Boot + Mybatis 项目整合,下载即可运行

    Spring Boot 和 Mybatis 的整合是现代 Java Web 开发中常见的技术栈组合,它们为开发者提供了高效、便捷的开发体验。Spring Boot 是 Spring 框架的简化版,它旨在简化初始设置和日常开发工作,而 Mybatis 是一个轻量...

    spring boot+mybatis+thymeleaf+apache shiro开发面向学习型的后台管理系统BootDo

    spring boot+mybatis+thymeleaf+apache shiro开发面向学习型的后台管理系统BootDo,参考地址 http://blog.csdn.net/zhaokejin521/article/details/78719722

    h2嵌入式数据库例子 springboot+h2+mybatisplus+swagger使用例子

    springboot+h2+mybatisplus+swagger使用例子 h2数据库例子 H2是一个开源的嵌入式数据库引擎,采用java语言编写,不受平台的限制,同时H2提供了一 个十分方便的web控制台用于操作和管理数据库内容。H2还提供兼容...

    基于SpringBoot2+Jpa+SpringSecurity+redis+Vue的前后端分离系统

    基础框架:Spring Boot 2.1.0.RELEASE 持久层框架:Spring boot Jpa 安全框架:Spring Security 缓存框架:Redis 日志打印:logback+log4jdbc 接口文档 swagger2 其他:fastjson,aop,MapStruct等。 页面框架:Vue ...

    使用SpringBoot+SpringJPA+Swagger+Shiro快速搭建前后端分离的权限管理系统源码,方便二次开发

    使用SpringBoot+SpringJPA+Swagger+Shiro快速搭建前后端分离的权限管理系统源码,方便二次开发,项目经过严格测试,确保可以运行! 快速搭建前后端分离的权限管理系统 提供一套基于SpringBoo+shiro的权限管理思路. ...

    spring boot+shiro+mybatis实现不同用户登录显示不同的权限菜单

    Spring Boot、Shiro和MyBatis这三大框架的组合提供了一种高效且灵活的方式来实现这一目标。本项目通过集成这三个工具,能够根据用户的登录身份展示不同的权限菜单,确保了用户只能访问他们被授权的功能。 **Spring ...

Global site tag (gtag.js) - Google Analytics