带有Swagger的Spring Rest API –集成和配置

如今,公开的API终于获得了应有的关注,公司也开始意识到其战略价值。 但是,使用第三方API确实是一项繁琐的工作,尤其是当这些API维护不当,设计不当或缺少任何文档时。 这就是为什么我决定四处寻找可以为集成编程人员和其他团队成员提供适当文档的方法的原因。 一种方式是使用WADL,WADL是专门设计用于描述基于HTTP的Web应用程序(如REST Web服务)的标准。 但是,使用WADL时几乎没有什么缺点,这使我无法在其他地方寻找如何正确记录和公开API文档的解决方案。

昂首阔步

另一种方法可能是与Swagger一起使用。 Swagger是规范和框架实现,均支持RESTful Web服务开发的整个生命周期。 规范本身是与语言无关的,在异构环境中可能会派上用场。 Swagger还带有Swagger UI模块,该模块允许程序员和其他团队成员与API进行有意义的交互,并为他们提供了一种使用它的方式,同时提供了对文档的访问权限。

Spring with Jersey示例

不久前,我遇到了一篇描述Swagger规范的文章,我很感兴趣尝试一下。 那时,我正在开发一种不错的微服务,因此我有一个理想的测试场来进行尝试。 基于此,我准备了一个简短的示例,说明了在使用Spring框架和Jersey时如何在应用程序中使用Swagger。 示例代码模型简化了商店应用程序场景中可能的API子集的REST API。

注意:所有Java代码示例均省略了导入声明。

泽西小服务程序

在开始将Swagger引入我们的代码之前,让我们花点时间来探讨一下我们的示例。 首先,让我们看一下web.xml 。 下面的代码示例中有简单的旧web.xml ,几乎没有简单的声明和映射。 这里没什么特别的,只是一堆配置。

<web-app id="SpringWithSwagger" version="2.4" xmlns="http://java.sun.com/xml/ns/j2ee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd"><display-name>Spring Jersey Swagger Example</display-name><context-param><param-name>contextConfigLocation</param-name><param-value>classpath:beans.xml</param-value></context-param><listener><listener-class>org.springframework.web.context.ContextLoaderListener</listener-class></listener><servlet><servlet-name>jersey-serlvet</servlet-name><servlet-class>org.glassfish.jersey.servlet.ServletContainer</servlet-class><init-param><param-name>javax.ws.rs.Application</param-name><param-value>com.jakubstas.swagger.SpringWithSwagger</param-value></init-param><load-on-startup>1</load-on-startup></servlet><servlet-mapping><servlet-name>jersey-serlvet</servlet-name><url-pattern>/rest/*</url-pattern></servlet-mapping>
</web-app>

终点

我们需要的第二件事是定义我们的REST服务的端点-例如用于列出当前雇员的雇员端点。 再一次,没有什么特别的,只有少数提供核心API功能的公开方法。

package com.jakubstas.swagger.rest;@Path("/employees")
public class EmployeeEndpoint {private List<Employee> employees = new ArrayList<Employee>();{final Employee employee = new Employee();employee.setEmployeeNumber(1);employee.setFirstName("Jakub");employee.setSurname("Stas");employees.add(employee);}@OPTIONSpublic Response getProductsOptions() {final String header = HttpHeaders.ALLOW;final String value = Joiner.on(", ").join(RequestMethod.GET, RequestMethod.OPTIONS).toString();return Response.noContent().header(header, value).build();}@GET@Produces(MediaType.APPLICATION_JSON)public Response getEmployees() {return Response.ok(employees).build();}
}

昂首阔步的依赖

我们要做的第一件事是在pom.xml包含所有必需的Swagger依赖项,如下所示(幸运的是,这只是一个依赖项)。

<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/maven-v4_0_0.xsd">...<properties>...<swagger-version>1.3.8</swagger-version>...</properties>...<dependencies>	...<!-- Swagger --><dependency><groupId>com.wordnik</groupId><artifactId>swagger-jersey2-jaxrs_2.10</artifactId><version>${swagger-version}</version></dependency>...</dependencies>
</project>

昂首阔步的配置

现在,让我们看一下Swagger如何集成到我们的示例中。 与在项目中引入任何新依赖项一样,您应该关注此过程的侵入性和成本。 受影响的唯一地方将是您的REST端点,Spring配置和一些传输对象(假设您选择包括它们),如以下代码示例中所示。 这意味着Swagger不需要在web.xml进行配置即可与您的Spring应用程序一起使用,这意味着它以这种方式是非侵入性的,并且仍受API领域的限制。

您需要Swagger才能使用三个基本属性:

  • API版本
    • 提供应用程序API的版本
  • 基本路径
    • 提供API的根URL
  • 资源包
    • 定义在哪里寻找Swagger注释的包

由于API维护主要由分析人员和程序员负责,因此我希望将此配置保存在名为swagger.properties的单独属性文件中。 这样,它就不会与应用程序配置混合在一起,并且不太可能被意外修改。 以下片段描述了这样的配置文件。

swagger.apiVersion=1.0
swagger.basePath=http://[hostname/ip address]:[port]/SpringWithSwagger/rest
swagger.resourcePackage=com.jakubstas.swagger.rest

对于配置的第二部分,我利用前面提到的属性创建了一个配置bean。 使用Spring的@PostConstruct批注提供bean生命周期挂钩,我们可以实例化和设置Swagger所需的某些属性,但不能获取(至少在当前版本中)。

package com.jakubstas.swagger.rest.config;/*** Configuration bean to set up Swagger.*/
@Component
public class SwaggerConfiguration {@Value("${swagger.resourcePackage}")private String resourcePackage;@Value("${swagger.basePath}")private String basePath;@Value("${swagger.apiVersion}")private String apiVersion;@PostConstructpublic void init() {final ReflectiveJaxrsScanner scanner = new ReflectiveJaxrsScanner();scanner.setResourcePackage(resourcePackage);ScannerFactory.setScanner(scanner);ClassReaders.setReader(new DefaultJaxrsApiReader());final SwaggerConfig config = ConfigFactory.config();config.setApiVersion(apiVersion);config.setBasePath(basePath);}public String getResourcePackage() {return resourcePackage;}public void setResourcePackage(String resourcePackage) {this.resourcePackage = resourcePackage;}public String getBasePath() {return basePath;}public void setBasePath(String basePath) {this.basePath = basePath;}public String getApiVersion() {return apiVersion;}public void setApiVersion(String apiVersion) {this.apiVersion = apiVersion;}
}

最后一步是声明以下三个Swagger bean: ApiListingResourceJSONApiDeclarationProviderResourceListingProvider

<beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd"><context:component-scan base-package="com.jakubstas.swagger" /><context:property-placeholder location="classpath:swagger.properties" /><bean class="com.wordnik.swagger.jaxrs.listing.ApiListingResourceJSON" /><bean class="com.wordnik.swagger.jaxrs.listing.ApiDeclarationProvider" /><bean class="com.wordnik.swagger.jaxrs.listing.ResourceListingProvider" />
</beans>

现已配置Swagger,您可以检查设置是否正常运行。 只需从basePath变量中输入URL,然后在浏览器中输入/api-docs并检查结果即可。 在我的示例中,您应该看到类似于访问http://[hostname]:[port]/SpringWithSwagger/rest/api-docs/后收到的以下代码片段的输出。

{"apiVersion":"1.0","swaggerVersion":"1.2"}

下一步是什么?

如果执行了所有步骤,则现在应该可以使用API​​文档开始进行设置。 在我的下一篇名为Swagger的Spring Rest API –创建文档中,我将展示如何使用Swagger注释描述API。 该微型系列中使用的代码在GitHub上发布,并提供了所有讨论的功能和工具的示例。 请享受!

翻译自: https://www.javacodegeeks.com/2014/10/spring-rest-api-with-swagger-integration-and-configuration.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/361977.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

A customized combobox with JQuery

要求实现一个轻量级的在客户端筛选的combobox&#xff0c;支持大数据量&#xff08;超过1000个items&#xff09;&#xff0c;能快速检索内容&#xff0c;并支持数据的设置和活动等基本操作。在这之前尝试过使用Jquery UI的Autocomplete&#xff0c;但是当数据量太大时客户端检…

使用内存回流的方法来实现将image的内容转换为 byte[]

在今天的开发中老大不知道怎么突发奇想&#xff0c;要使用Image的Byte数据。当时使用老几种方式效果均不理想&#xff0c;最后发现其实可以使用内存回流的方式来实现。多的不说老&#xff0c;马上贴上代码&#xff1a;/**//// <summary> /// 将byte[]转换为Image…

TypeScript中的class声明了什么

在初看TypeScript的时候在这里卡住的时间难以估计&#xff0c;并不能很好的理解”换个角度说&#xff0c;我们可以认为类具有 实例部分与 静态部分这两个部分。“这句话。今天再回头看这部分文档&#xff0c;在同事的帮助下突然有了比较通透的理解。 class Greeter {static st…

CentOS 6下搭建Apache+MySQL+PHP+SSL

网上的一些文章都已经比较老了&#xff0c;现在版本高了之后&#xff0c;其实配置是很省力的&#xff08;不考虑什么负载的话&#xff09; 分享全过程&#xff0c;出了文中提到的安装epel rpmfushion 源指令不同外&#xff0c;其他的过程也适用与Centos 5 1.安装CentOS 6 ,可以…

通过设计国际象棋游戏来了解策略模式

今天&#xff0c;我们将借助一个示例来尝试了解策略模式。 我们将考虑的示例是国际象棋游戏。 这里的目的是解释策略模式&#xff0c;而不是构建全面的国际象棋游戏解决方案。 策略模式&#xff1a;策略模式被称为行为模式-用于管理对象之间的算法&#xff0c;关系和职责。 策…

vs2010 问题 LINK : fatal error LNK1123: 转换到 COFF 期间失败: 文件无效或损坏

vs2010 问题 LINK : fatal error LNK1123: 转换到 COFF 期间失败: 文件无效或损坏 在安装 VS2010 后&#xff0c;再安装 VS2012 VS2015 等&#xff0c;原来的 .NET 4.0 会被替换为 .NET 4.5。不会恢复 .NET 4.0 。这时&#xff0c;VS2010的 cvtres.exe 就无法使用了。如果 PATH…

Nginx 使用try_files遇到的问题

背景&#xff1a; root /some/path; location / {try_files $uri $uri/ /dist/index.html; }使用React之类的的库来开发前端页面的时候&#xff0c;因为是单页应用所以需要上面的Nginx配置&#xff0c;用来在找不到html文件的时候内部重定向到/dist/index.html文件。 服务器上…

群发邮件

最近&#xff0c;通过两周的学习&#xff0c;对.net 的基础知识有了进一步的了解。觉得自己可以写个小程序了。于是花了两天时间写了一个 群发邮件的一个WinForm小程序。自己在这里小秀一下&#xff0c;表扬及鼓励一下自己。哈哈&#xff01; 此小程序在发送邮件的基础上还添加…

深入研究ES6 Generators

ES6 Generators系列&#xff1a; ES6 Generators基本概念深入研究ES6 GeneratorsES6 Generators的异步应用ES6 Generators并发 如果你还不知道什么是ES6 generators&#xff0c;请看我的前一篇文章“ES6 Generators基本概念” 。如果你已经对它有所了解&#xff0c;本文将带你…

在JavaEE中使用CDI的简单面向方面的编程(AOP)

我们编写满足特定业务逻辑的服务API。 涵盖所有服务API&#xff08;如安全性&#xff0c;日志记录&#xff0c;审核&#xff0c;度量延迟等&#xff09;的跨领域问题很少。 这是一个重复的非业务代码&#xff0c;可以在其他方法之间重用。 重用的一种方法是将这些重复的代码移入…

sessionStorage什么时候失效

最近在调试程序的时候无意间看到 cookie 的过期时间是 session&#xff0c;这个 session 表示的是什么时候过期&#xff1f;牵扯出来另一个存储方案 sessionStorage 存储的数据又是什么时候过期呢&#xff1f; 在查找相关资料的时候总会看到会话结束的时候 cookie 会被清除&am…

ES6 解构赋值详解

解构赋值是对赋值运算符的扩展&#xff0c;可以将属性/值从对象/数组中取出&#xff0c;赋值给其他变量。 一、数组的解构赋值 1、基本用法 只要等号两边的模式相同&#xff0c;左边的变量就会被赋予对应的值。 let [a, [[b], c]] [1, [[2], 3]]; a // 1 b // 2 c // 3 let [a…

软件著作权申请流程

一、填写计算机软件著作权登记申请表&#xff08;表格1份&#xff09;包括软件全称、简称、版本号、开发完成日期、软件开发情况&#xff08;独立开发、合作开发、委托开发、下达任务开发&#xff09;、原始取得权利情况、继受取得权利情况、权利范围、软件用途和技术特点&…

Npm install failed with “cannot run in wd”

Linux环境下&#xff0c;root账户&#xff0c;安装某些npm包的时候报下面的错误&#xff0c;例如安装grunt-contrib-imagemin时&#xff1a; Error: EACCES, mkdir /usr/local/lib/node_modules/coffee-scriptnpm ERR! { [Error: EACCES, mkdir /usr/local/lib/node_modules/c…

Java EE 7 Batch中传递属性/参数的2种方式

对于Java EE 7批处理工具&#xff0c;有两种将属性/参数传递给块和批处理的方法。 本快速指南向您展示了两种方式&#xff0c;在开发批处理Java EE 7方式时可能会经常使用它们。 1.运行前预定义的属性/参数 预定义属性是您在部署应用程序之前定义的属性&#xff08;名称/值对&…

Csharp 打印Word文件默認打印機或選擇打印機設置代碼

//打印文檔object nullobj Missing.Value;//aDoc wordApp.Documents.Open(ref file,// ref nullobj, ref nullobj, ref nullobj,// ref nullobj, ref nullobj, ref nullobj,// ref nullob…

ESLint共享配置的两种方式eslint-plugin和eslint-config

使用ESLint很久了&#xff0c;也看了ESLint官方文档很多遍&#xff0c;但对于ESLint配置的规则还是不胜清楚&#xff0c;例如&#xff1a; {"extends": ["plugin:prettier/recommended"] }上面extends的值为什么要"plugin:"开头&#xff1f;这里…

使用aggregate在MongoDB中查找重复的数据记录

我们知道&#xff0c;MongoDB属于文档型数据库&#xff0c;其存储的文档类型都是JSON对象。正是由于这一特性&#xff0c;我们在Node.js中会经常使用MongoDB进行数据的存取。但由于Node.js是异步执行的&#xff0c;这就导致我们无法保证每一次的数据库save操作都是原子型的。也…

Gradle入门:创建二进制分发

创建有用的应用程序之后&#xff0c;很可能我们想与其他人共享它。 一种方法是创建一个可以从我们的网站下载的二进制发行版。 这篇博客文章描述了如何满足以下要求的二进制发行版&#xff1a; 我们的二进制分发绝对不能使用所谓的“胖子”方法。 换句话说&#xff0c;我们的…

我的Google Adsense帐户被关

一、 上周四&#xff0c;我收到Google的邮件&#xff0c;宣布关闭我的Adsense帐户。 "您好&#xff01; 查看了相关记录后&#xff0c;我们确认您的 AdSense 帐户存在引起无效活动的风险。保护 AdWords 广告客户&#xff0c;使其免受无效活动的侵害是我们的责任&#xff0…