後端編寫Swagger介面管理文檔

来源:https://www.cnblogs.com/buchizicai/archive/2022/08/06/16517395.html
-Advertisement-
Play Games

Swagger介面管理文檔 訪問介面文檔的網頁:http://localhost:8080/swagger-ui/index.html 導入依賴 <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-boot-start ...


Swagger介面管理文檔

訪問介面文檔的網頁:http://localhost:8080/swagger-ui/index.html

導入依賴

<dependency>
    <groupId>io.springfox</groupId>
    <artifactId>springfox-boot-starter</artifactId>
    <version>3.0.0</version>
</dependency>

編寫yaml

SpringBoot 2.6以上版本修改了路徑匹配規則,但是Swagger3還不支持,這裡換回之前的,不然啟動直接報錯

spring:
	mvc:
		pathmatch:
      matching-strategy: ant_path_matcher

創建配置類配置swagger信息

這個是配置swagger網頁的大文字

@Configuration
public class SwaggerConfiguration {
    @Bean
    public Docket docket() {
        return new Docket(DocumentationType.OAS_30)
                .apiInfo(apiInfoMyself())
                .select()   //開啟選擇掃描介面功能
                .apis(RequestHandlerSelectors.basePackage("com.example.controller"))    //設置swagger只掃描該包下的介面(還可以設置只掃描每個類,某個方法)
                .build();
    }

    private ApiInfo apiInfoMyself(){
        return new ApiInfoBuilder()
                .contact(new Contact("你的名字", "https://www.bilibili.com", "javastudy111*@163.com"))
                .title("圖書館里系統——線上api介面文檔")
                .description("歡迎各位前端大佬前來訪問介面")
                .version("1.1") //自己隨便定義這個介面第幾版的
                .build();
    }
}

添加具體描述

//為xxxcontroller這個類加註解
@Api(tags = "賬戶驗證介面", description = "包括用戶登錄、註冊、驗證碼請求等操作。")
@RestController
@RequestMapping("/api/auth")
public class AuthApiController {
    
//為某個介面添加註解
@ApiResponses({
        @ApiResponse(code = 200, message = "郵件發送成功"),  
        @ApiResponse(code = 500, message = "郵件發送失敗")   //不同返回狀態碼描述
})
@ApiOperation("請求郵件驗證碼")   //介面描述
@GetMapping("/verify-code")
public RestBean<Void> verifyCode(@ApiParam("郵箱地址") @RequestParam("email") String email,//請求參數的描述
                                @ApiParam("郵箱地址") @RequestParam("email") String email){
    
//讓swagger忽略每個介面
@ApiIgnore     //忽略此請求映射
@PostMapping("/login-success")
public RestBean<Void> loginSuccess(){
    return new RestBean<>(200, "登陸成功");
}
    
//為實體類添加描述(因為有時候會返回一個實體類,所以需要告訴前端人員這個實體類描述的是啥)
@Data
@ApiModel(description = "響應實體封裝類")
@AllArgsConstructor
public class RestBean<T> {

    @ApiModelProperty("狀態碼")
    int code;
    @ApiModelProperty("狀態碼描述")
    String reason;
    @ApiModelProperty("數據實體")
    T data;

    public RestBean(int code, String reason) {
        this.code = code;
        this.reason = reason;
    }
}
    

如果有配置多環境,prod生產環境就沒必要開啟swagger了

springfox:
  documentation:
    enabled: false

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 閑來無事,總結一下公司使用的 微服務框架,文章所有代碼GtiHub:https://github.com/Tom-shushu/work-study 裡面的gateway-server和server1項目 1、Docker 部署 Nacos 資料庫準備 新建 "nacos_config" 資料庫 # ...
  • C語言的迴圈結構,有for(;;)迴圈,while()迴圈,do~while()迴圈,for迴圈使用最頻繁,三種語句都可以銜接break;continue;來進行中斷迴圈。 在for(;;)迴圈結構中,分號所隔開的語句是(初始化;判斷;調整),當都省略時即直接使用for(;;)時,預設為真,即進入死 ...
  • TortoiseGit 人稱小烏龜插件是一個來源的版本控制客戶端,和git功能類似, 不過相對於git支持界面操作. TortoiseGit下載地址: 點我下載 當前穩定版本是2.6.0, 建議下載此版本, 下麵是下載過程(winx64位系統): 預設是英文安裝, 需要中文的情況可以下載中文語言包 ...
  • redis入門 redis的常見五種數據類型 String類型 String類型,類似於java中的String類型,常見使用get,set方法。 ==String類型還可以存儲json字元串格式==。 Hash類型 Hash類型,也叫散列,它的value是一個無序字典,類似於java中HashMa ...
  • 目錄 一.簡介 二.效果演示 三.源碼下載 四.猜你喜歡 零基礎 OpenGL (ES) 學習路線推薦 : OpenGL (ES) 學習目錄 >> OpenGL ES 基礎 零基礎 OpenGL (ES) 學習路線推薦 : OpenGL (ES) 學習目錄 >> OpenGL ES 轉場 零基礎 O ...
  • 背景 某個周末一個線上項目因為伺服器自動重啟導致了系統掛了,我們是通過jenkins部署的jar包所以需要手動重啟項目,解決問題後準備調換部署方式讓項目隨系統自動啟動,試用tomcat後發現啟動慢,並且日常開發springboot都是使用內置tomcat啟動,如果要保持和部署方式保持一致(避免本地代 ...
  • 1.七個網站的Python實戰代碼 1.汽車之家 def t1(): #汽車之家 ##請上傳JPG、JPEG、BMP格式圖片 import requests from requests_toolbelt import MultipartEncoder from bs4 import Beautifu ...
  • Java中線程的狀態類型 線程的狀態類型 源碼作者的原註釋關於線程內部類State描述了線程的六個狀態 A thread state. A thread can be in one of the following states: ①、NEW 尚未啟動的線程處於此狀態 源碼中的註釋 A thread ...
一周排行
    -Advertisement-
    Play Games
  • 概述:本文代碼示例演示瞭如何在WPF中使用LiveCharts庫創建動態條形圖。通過創建數據模型、ViewModel和在XAML中使用`CartesianChart`控制項,你可以輕鬆實現圖表的數據綁定和動態更新。我將通過清晰的步驟指南包括詳細的中文註釋,幫助你快速理解並應用這一功能。 先上效果: 在 ...
  • openGauss(GaussDB ) openGauss是一款全面友好開放,攜手伙伴共同打造的企業級開源關係型資料庫。openGauss採用木蘭寬鬆許可證v2發行,提供面向多核架構的極致性能、全鏈路的業務、數據安全、基於AI的調優和高效運維的能力。openGauss深度融合華為在資料庫領域多年的研 ...
  • openGauss(GaussDB ) openGauss是一款全面友好開放,攜手伙伴共同打造的企業級開源關係型資料庫。openGauss採用木蘭寬鬆許可證v2發行,提供面向多核架構的極致性能、全鏈路的業務、數據安全、基於AI的調優和高效運維的能力。openGauss深度融合華為在資料庫領域多年的研 ...
  • 概述:本示例演示了在WPF應用程式中實現多語言支持的詳細步驟。通過資源字典和數據綁定,以及使用語言管理器類,應用程式能夠在運行時動態切換語言。這種方法使得多語言支持更加靈活,便於維護,同時提供清晰的代碼結構。 在WPF中實現多語言的一種常見方法是使用資源字典和數據綁定。以下是一個詳細的步驟和示例源代 ...
  • 描述(做一個簡單的記錄): 事件(event)的本質是一個委托;(聲明一個事件: public event TestDelegate eventTest;) 委托(delegate)可以理解為一個符合某種簽名的方法類型;比如:TestDelegate委托的返回數據類型為string,參數為 int和 ...
  • 1、AOT適合場景 Aot適合工具類型的項目使用,優點禁止反編 ,第一次啟動快,業務型項目或者反射多的項目不適合用AOT AOT更新記錄: 實實在在經過實踐的AOT ORM 5.1.4.117 +支持AOT 5.1.4.123 +支持CodeFirst和非同步方法 5.1.4.129-preview1 ...
  • 總說周知,UWP 是運行在沙盒裡面的,所有許可權都有嚴格限制,和沙盒外交互也需要特殊的通道,所以從根本杜絕了 UWP 毒瘤的存在。但是實際上 UWP 只是一個應用模型,本身是沒有什麼許可權管理的,許可權管理全靠 App Container 沙盒控制,如果我們脫離了這個沙盒,UWP 就會放飛自我了。那麼有沒... ...
  • 目錄條款17:讓介面容易被正確使用,不易被誤用(Make interfaces easy to use correctly and hard to use incorrectly)限制類型和值規定能做和不能做的事提供行為一致的介面條款19:設計class猶如設計type(Treat class de ...
  • title: 從零開始:Django項目的創建與配置指南 date: 2024/5/2 18:29:33 updated: 2024/5/2 18:29:33 categories: 後端開發 tags: Django WebDev Python ORM Security Deployment Op ...
  • 1、BOM對象 BOM:Broswer object model,即瀏覽器提供我們開發者在javascript用於操作瀏覽器的對象。 1.1、window對象 視窗方法 // BOM Browser object model 瀏覽器對象模型 // js中最大的一個對象.整個瀏覽器視窗出現的所有東西都 ...