国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

Spring Data REST API集成Springfox、Swagger

darcrand / 1232人閱讀

摘要:請注意,截至目前版本,用于的集成仍處于孵化階段,并且存在一些嚴重的錯誤和缺少的功能例如,請參閱此處和此處。響應可以使用和注解來調(diào)整不同的響應狀態(tài)及其有效結(jié)論允許您在創(chuàng)建數(shù)據(jù)庫驅(qū)動的時產(chǎn)生快速結(jié)果。

原文: Documenting a Spring Data REST API with Springfox and Swagger

使用Spring Date REST,你可以迅速為Spring Date repositories的創(chuàng)建REST API,并提供CRUD和更多功能。然而,在嚴謹?shù)腁PI開發(fā)過成功,您還希望擁有自動生成的最新API文檔。

Code Example

本文附帶了工作示例代碼[github]()

Swagger提供了一個用于記錄REST API的規(guī)范。通過使用Springfox,我們有一個工具可以作為Spring應用程序和Swagger之間的橋梁,為某些Spring bean和注釋創(chuàng)建一個Swagger文檔。

Springfox最近還添加了一個為Spring Data REST API創(chuàng)建Swagger文檔的功能。 這個功能還在孵化,但是我仍然玩了一下,以評估它是否可以在真實項目中使用。 因為如果是這樣,Spring Data REST和Springfox的結(jié)合將允許快速開發(fā)一個記錄良好的REST API。

請注意,截至目前(版本2.7.0),用于Spring Data REST的Springfox集成仍處于孵化階段,并且存在一些嚴重的錯誤和缺少的功能(例如,請參閱此處和此處)。 因此,下面的說明和代碼示例基于當前的2.7.1-SNAPSHOT版本,其中可以大大改進。

在Spring Boot / Spring Data REST應用程序中啟用Springfox

為了使Springfox能夠為我們的Spring Data REST API創(chuàng)建一個Swagger文檔,您必須執(zhí)行以下步驟。

添加Springfox依賴

將以下依賴項添加到您的應用程序(gradle)中:

compile("io.springfox:springfox-swagger2:2.7.0")
compile("io.springfox:springfox-data-rest:2.7.0")
compile("io.springfox:springfox-swagger-ui:2.7.0")

springfox-swagger2包含Springfox的核心功能,允許使用Swagger 2創(chuàng)建API文檔。

springfox-data-rest包含為Spring Data REST存儲庫自動創(chuàng)建Swagger文檔的集成。

springfox-swagger-ui包含Swagger UI,它在http:// localhost:8080 / swagger-ui.html中顯示Swagger文檔

配置Application

按下面的方法配置Spring Boot Application:

@SpringBootApplication
@EnableSwagger2
@Import(SpringDataRestConfiguration.class)
public class DemoApplication {
  
  public static void main(String[] args) {
    SpringApplication.run(DemoApplication.class, args);
  }
  
}

@EnableSwagger2注解通過在Spring應用程序上下文中注冊某些bean來啟用Swagger 2支持。

@Import注釋將額外的類導入到Spring應用程序上下文中,這些需要從Spring Data REST存儲庫自動創(chuàng)建Swagger文檔。

創(chuàng)建Docket bean

你可以選擇創(chuàng)建一個Docket類型的Spring bean。 這將被Springfox拿起來配置一些swagger文檔輸出。

@Configuration
public class SpringfoxConfiguration {
  
  @Bean
  public Docket docket() {
    return new Docket(DocumentationType.SWAGGER_2)
      .tags(...)
      .apiInfo(...)
      ...
  }
  
}
Spring Data repositories添加注解

另外可選地,您可以使用@Api,@ApiOperation和@ApiParam注釋來注釋由Spring Data REST公開的Spring Data存儲庫。 以下更多細節(jié)。

輸出

最后,通過訪問瀏覽器中的http:// localhost:8080 / swagger-ui.html,您應該能夠查看Spring Data REST API的Swagger文檔。 結(jié)果應該如下圖所示。

自定義輸出

上圖中的數(shù)字顯示了一些可以自定義生成的API文檔中的東西的地方。 以下各節(jié)介紹了我認為重要的一些定制。 你可以定制超過我發(fā)現(xiàn)的東西,所以隨時添加評論,如果你發(fā)現(xiàn)我錯過的東西!

通用的API信息

像標題,描述,許可等信息可以通過創(chuàng)建一個 Docket bean來配置,如上面的代碼片段,并使用其setter來更改所需的設置。

Repository描述

可以通過創(chuàng)建一個名稱與默認API名稱完全相同的標記(示例中的“地址實體”)來更改存儲庫的描述,并向 Docket 對象中的此標記提供描述,并使用 @Api 將該標記庫與該標記庫相連接 注解。 到目前為止,我找不到修改存儲庫名稱的方法。

@Configuration
public class SpringfoxConfiguration {
  
  @Bean
  public Docket docket() {
    return new Docket(DocumentationType.SWAGGER_2)
      .tags(new Tag("Address Entity", "Repository for Address entities"));
  }
  
}

@Api(tags = "Address Entity")
@RepositoryRestResource(path = "addresses")
public interface AddressRepository extends CrudRepository {
  // methods omitted
}
方法描述

對單個API操作的描述可以通過 @ApiOperation 注釋來修改,如下所示:

public interface AddressRepository extends PagingAndSortingRepository {
  
  @ApiOperation("find all Addresses that are associated with a given Customer")
  Page
findByCustomerId(@Param("customerId") Long customerId, Pageable pageable); }
輸入?yún)?shù)

輸入?yún)?shù)的名稱和描述可以使用 @ApiParam 注釋進行配置。 請注意,從Springfox 2.7.1開始,參數(shù)名稱也從Spring Data提供的 @Param 注釋中讀取。

public interface AddressRepository extends PagingAndSortingRepository {
  
  Page
findByCustomerId(@Param("customerId") @ApiParam(value="ID of the customer") Long customerId, Pageable pageable); }
響應

可以使用 @ApiResponses@ApiResponse 注解來調(diào)整不同的響應狀態(tài)及其有效payload:

public interface AddressRepository extends PagingAndSortingRepository {
    
  @Override
  @ApiResponses({@ApiResponse(code=201, message="Created", response=Address.class)})
  Address save(Address address);
  
}
結(jié)論

Spring Data REST允許您在創(chuàng)建數(shù)據(jù)庫驅(qū)動的REST API時產(chǎn)生快速結(jié)果。 Springfox允許您快速生成該API的自動文檔。但是,由Springfox生成的API文檔與每個細節(jié)中的實際API都不匹配。一些手動微調(diào)和注釋是必要的,如上面的定制部分所述。

一個這樣的例子是,示例請求和響應的JSON在每種情況下都不能正確地呈現(xiàn),因為Spring Data REST使用HAL格式,Springfox僅在少數(shù)情況下使用。通過手動工作,API文檔很難保持每個細節(jié)的最新狀態(tài)。

我的結(jié)論是,Spring Data REST和Springfox的結(jié)合是一個很好的起點,可以快速生成一個REST API,它的文檔對于大多數(shù)用例來說足夠好,特別是當API是在一組封閉的開發(fā)人員中開發(fā)和使用的時候。對于公共API,細節(jié)更重要一點,讓Swagger注釋和Springfox配置保持最新的每個細節(jié)可能令人沮喪。

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/68791.html

相關文章

  • Java | Spring Boot Swagger2 集成REST ful API 生成接口文檔

    摘要:集成生成接口文檔原文簡介由于的特性,用來開發(fā)變得非常容易,并且結(jié)合來自動生成文檔變得方便快捷。使用生成,我們可以得到交互式文檔。聽過與的結(jié)合,生成更加完備的文檔。接下來將基于與搭建完整的文檔系統(tǒng)。 Spring Boot Swagger2 集成REST ful API 生成接口文檔 原文 簡介 由于Spring Boot 的特性,用來開發(fā) REST ful 變得非常容易,并且結(jié)合 Sw...

    joyvw 評論0 收藏0
  • spring boot 集成swagger并且使用攔截器的配置問題

    摘要:另外的解決方案網(wǎng)上還有另外一種說法,可以實現(xiàn)接口,代碼如下用于添加攔截規(guī)則,先把所有路徑都加入攔截,再一個個排除自定義規(guī)則,如果遇到,則把泛型類轉(zhuǎn)成通用服務易保科技但是這種配置想要生效,必須加注解,不然不起作用。 最近同事問我,spring boot集成了swagger,但是在使用攔截器的時候遇到了問題,頁面無法訪問。經(jīng)過研究解決了這個問題。 配置問題解決 集成swagger就不啰嗦了...

    fsmStudy 評論0 收藏0
  • Spring Boot [如何優(yōu)雅的編寫文檔]

    摘要:導讀在團隊協(xié)作的時候許多時候需要用到接口文檔,我們通常通過手工編寫大量重復格式的文檔,讓我想起了程序員最討厭的兩件事沒有文檔,編寫文檔。對應的資料可自行谷歌。關于和官網(wǎng)是這樣描述的。我們可以理解為為基于構(gòu)建的自動生成文檔。 導讀: 在團隊協(xié)作的時候許多時候需要用到接口文檔,我們通常通過手工編寫大量重復格式的文檔,讓我想起了程序員最討厭的兩件事:沒有文檔,編寫文檔。哈哈,如果使用過swa...

    曹金海 評論0 收藏0
  • SpringBoot 實戰(zhàn) (五) | 集成 Swagger2 構(gòu)建強大的 RESTful API

    摘要:今天給你們帶來集成的教程。接口返回結(jié)果不明確。這些痛點在前后端分離的大型項目上顯得尤為煩躁。接口返回結(jié)果非常明確,包括數(shù)據(jù)類型,狀態(tài)碼,錯誤信息等。生成后的文件依賴如下這里使用的是的版本。另外,關注之后在發(fā)送可領取免費學習資料。 微信公眾號:一個優(yōu)秀的廢人如有問題或建議,請后臺留言,我會盡力解決你的問題。 前言 快過年了,不知道你們啥時候放年假,忙不忙。反正我是挺閑的,所以有時間寫 b...

    Rindia 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<