首頁 Java java教程 使用Spring Boot和Swagger來建立RESTful API文檔

使用Spring Boot和Swagger來建立RESTful API文檔

Jun 23, 2023 pm 01:51 PM
spring boot swagger restful api

在當今的Web開發中,RESTful API已經成為了開發者們非常流行的方式來建立網站和應用程式。使用RESTful API,開發者能夠建立出清晰明了的API,更方便的與其他應用程式或服務互動。而為了能夠更好地管理和維護這些API,文件的編寫和管理也成為了非常關鍵的一部分。

Spring Boot是一款快速建立Java應用程式的框架,具有簡單、快速、易於擴展的功能。而Swagger則是一款專門用於設計、建構和文檔化RESTful API的工具,能夠快速地產生RESTful API文檔,並自動產生API的請求和響應的範例流。

本文將會介紹如何使用Spring Boot和Swagger來建立RESTful API文件。

一、創建Spring Boot項目

首先,我們需要使用Spring Initializr創建一個Spring Boot項目,可以透過https://start.spring.io/來進行創建。在這裡,我們選擇Web和Swagger 2這兩個依賴。創建完成後,我們導入專案到整合開發環境中,並在pom.xml中加入Swagger的依賴:

<dependency>
   <groupId>io.springfox</groupId>
   <artifactId>springfox-swagger2</artifactId>
   <version>2.9.2</version>
</dependency>
<dependency>
   <groupId>io.springfox</groupId>
   <artifactId>springfox-swagger-ui</artifactId>
   <version>2.9.2</version>
</dependency>
登入後複製

二、建立RESTful API

在這裡我們建立一個簡單的RESTful API,用於產生一個隨機數。

我們在Controller中加入一個方法:

@RestController
public class NumberController {
 
   @ApiOperation(value = "Generate a random number between 1 and 100")
   @RequestMapping(value = "/generateNumber", method = RequestMethod.GET)
   public ResponseEntity<Integer> generateNumber() {
       Random random = new Random();
       int randomNumber = random.nextInt(100) + 1;
       return ResponseEntity.ok(randomNumber);
   }
}
登入後複製

要注意的是,在類別上不僅需要加入@RestController註解,還需要使用@Api註解來描述這個Controller的作用。

反編譯後的內容:

package com.example.demo.controller;

import io.swagger.annotations.ApiOperation;
import org.springframework.http.ResponseEntity;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;

import java.util.Random;

@RestController
public class NumberController
{

    public NumberController()
    {
    }

    @ApiOperation(value="Generate a random number between 1 and 100")
    @RequestMapping(value="/generateNumber", method=RequestMethod.GET)
    public ResponseEntity generateNumber()
    {
        Random random = new Random();
        int randomNumber = random.nextInt(100) + 1;
        return ResponseEntity.ok(new Integer(randomNumber));
    }
}
登入後複製

三、設定Swagger

在完成了對應的Controller的開發之後,我們需要進行Swagger的設定。在Spring Boot的設定檔application.properties中加入Swagger的相關配置。

#指定Swagger API扫描的路径
swagger.basePackage=com.example.demo.controller
 
#应用名称
swagger.title=Spring Boot Swagger Example
 
#版本号
swagger.version=1.0.0
 
#描述信息
swagger.description=This is a demo service for Spring Boot Swagger.
 
#联系人信息
swagger.contact.name=John Doe
swagger.contact.url=http://www.example.com
swagger.contact.email=john.doe@example.com
登入後複製

註解說明:

@Api:用來描述Controller的作用,類似Spring MVC中的@Controller和@RequestMapping註解。

@ApiIgnore:用於被忽略的API,不會在產生的API文件中顯示。

@ApiOperation:用來描述特定的API操作,包括方法名稱、請求方法、請求參數、傳回物件等訊息,可以放在方法上面或是類別上面。

@ApiImplicitParam:用於描述請求參數,包括參數名稱、參數類型、必須性等資訊。

@ApiModel:用來描述JavaBean類別。

@ApiParam:用於描述參數資訊。

@ApiResponses:用來描述API的回應,包括HTTP狀態碼、回應資料等資訊。

@ApiProperty:用來描述JavaBean類別的屬性資訊。

四、檢視API文件

在完成了上述的設定後,我們啟動這個Spring Boot應用,並造訪http://localhost:8080/swagger-ui.html。我們就可以在瀏覽器中查看到產生的API文件了。在這裡我們可以查看到我們剛剛編寫的API的詳細信息,包括請求方法、請求參數、返回結果等等。同時,Swagger也能夠產生一個請求和回應的範例流,方便開發者們進行引用和測試。

在這裡,我們使用Spring Boot和Swagger來建立RESTful API文件。使用這樣的方式,開發者們能夠更快速地建立和管理自己的API文檔,提升開發的效率和可維護性。

以上是使用Spring Boot和Swagger來建立RESTful API文檔的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

<🎜>:泡泡膠模擬器無窮大 - 如何獲取和使用皇家鑰匙
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系統,解釋
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora:巫婆樹的耳語 - 如何解鎖抓鉤
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1669
14
CakePHP 教程
1428
52
Laravel 教程
1329
25
PHP教程
1273
29
C# 教程
1256
24
如何使用Spring Boot建立大數據處理應用 如何使用Spring Boot建立大數據處理應用 Jun 23, 2023 am 09:07 AM

隨著大數據時代的到來,越來越多的企業開始了解並認識到大數據的價值,並將其運用到商業中。而隨之而來的問題就是如何處理這些大流量的數據。在這種情況下,大數據處理應用程式成為了每個企業必須考慮的事情。而對於開發人員而言,如何使用SpringBoot建立一個高效的大數據處理應用程式也是一個非常重要的問題。 SpringBoot是一個非常流行的Java框架,它可以讓

Spring Boot+MyBatis+Atomikos+MySQL(附源碼) Spring Boot+MyBatis+Atomikos+MySQL(附源碼) Aug 15, 2023 pm 04:12 PM

我們在實際專案中,盡量規避分散式事務。但是,有些時候是真的需要做一些服務拆分從而會引出分散式事務問題。同時,分散式事務也是面試中市場被問到,可以拿著這個案例練練手,面試就可以說上個123了。

透過Spring Boot實現多語言支援和國際化應用 透過Spring Boot實現多語言支援和國際化應用 Jun 23, 2023 am 09:09 AM

隨著全球化的發展,越來越多的網站和應用需要提供多語言支援和國際化功能。對於開發人員而言,實現這些功能並不是一件容易的事情,因為它需要考慮許多方面的問題,例如語言的翻譯、日期、時間和貨幣格式等等。但是,使用SpringBoot框架,我們可以輕鬆實現多語言支援和國際化應用。首先,讓我們來了解一下SpringBoot提供的LocaleResolver介面。 Loc

Spring Boot 實作 MySQL 讀寫分離技術 Spring Boot 實作 MySQL 讀寫分離技術 Aug 15, 2023 pm 04:52 PM

如何實現讀寫分離,Spring Boot項目,資料庫是MySQL,持久層用的是MyBatis。

PHP中利用路由模組實現RESTful API的設計與開發 PHP中利用路由模組實現RESTful API的設計與開發 Oct 15, 2023 am 11:36 AM

PHP中利用路由模組實現RESTfulAPI的設計與開發隨著互聯網的不斷發展,基於Web的應用程式越來越多,而REST(RepresentationalStateTransfer)介面已成為設計和開發Web服務的常見方法。在PHP中,實作RESTfulAPI可以透過路由模組來簡化開發和管理。本文將介紹如何使用PHP中的路由模組來設計與開發RES

Docker和Spring Boot的技術實踐:快速建立高效能的應用服務 Docker和Spring Boot的技術實踐:快速建立高效能的應用服務 Oct 21, 2023 am 08:18 AM

Docker和SpringBoot的技術實踐:快速建立高效能的應用服務引言:在當今的資訊時代,網路應用的開發和部署變得越來越重要。隨著雲端運算和虛擬化技術的快速發展,Docker作為一個輕量級的容器技術,受到了廣泛關注和應用。而SpringBoot作為快速開發和部署Java應用的框架,也得到了廣泛認可。本文將探討如何結合Docker和SpringB

Spring Boot中使用WebSocket實現推播與通知功能 Spring Boot中使用WebSocket實現推播與通知功能 Jun 23, 2023 am 11:47 AM

在現代Web應用程式開發中,WebSocket是實現即時通訊和即時資料傳輸的常用技術。 SpringBoot框架提供了整合WebSocket的支持,讓開發者可以非常方便地實現推播和通知功能。本文將介紹SpringBoot中如何使用WebSocket實現推播和通知功能,並示範一個簡單的即時線上聊天室的實作。創建SpringBoot專案首先,我們需要創建一個

如何在PHP中實現RESTful API的整合測試 如何在PHP中實現RESTful API的整合測試 Sep 06, 2023 pm 03:19 PM

如何在PHP中實現RESTfulAPI的整合測試隨著Web應用的發展和RESTfulAPI的流行,對於API的整合測試變得越來越重要。在PHP中,我們可以利用一些工具和技術來實現這樣的整合測試。本文將介紹如何在PHP中實現RESTfulAPI的整合測試,並提供一些範例程式碼來幫助您理解。使用PHPUnit進行整合測試PHPUnit是PHP中最流行的單元測

See all articles