在現在的開發過程中,基本上已經全部採用API 介面的方式進行系統的開發了,於是乎,在此過程中,一個好的API 文件便成為了後台與前台進行溝通與開發的關鍵橋樑。
傳統的做法是由開發人員創建一份RESTful API 文件來記錄所有的介面細節,說實話,這樣的工作量並不小,而且十分瑣碎,且隨著專案的更新會出現以下問題。
文件難以維護。
介面內容更複雜,寫效率更低。
Swagger 便是為了解決這個問題,它作為一個規格和完整的框架,可以用來產生、描述、呼叫和視覺化RESTful 風格的Web 服務:
透過Swagger,我們可以在開發介面的過程中透過使用註解自動產生/更新API 介面文檔,且在文檔頁面支援介面的偵錯。
接下來就簡單說一下,如何在SpringBoot 中整合Swagger2(2 代表其版本)
引入Swagger2 依賴
pom.xml 文件
<dependencies> <!--Swagger2 在此,个人推荐使用2.8.0版本,较为稳定--> <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swagger2</artifactId> <version>2.8.0</version> </dependency> <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swagger-ui</artifactId> <version>2.8.0</version> </dependency> </dependencies>
建立設定檔
Swagger2Config.java java 設定檔
@Configuration // 指定扫描的api包路径 @ComponentScan(basePackages = {"cn.beatree.xxx.controller"}) //注解开启 swagger2 功能 @EnableSwagger2 public class Swagger2Config { @Value("${swagger2.enable}") boolean enable; // 配置文件中通过值注入控制生产环境与开发环境下的启用状态 @Bean public Docket createRestApi() { return new Docket(DocumentationType.SWAGGER_2) .enable(enable) .apiInfo(apiInfo()) .select() .apis(RequestHandlerSelectors.any()) .paths(PathSelectors.any()) .build(); } private ApiInfo apiInfo() { return new ApiInfoBuilder() .title("ANONVOTE | Swagger API文档")//标题 .description("description: ANONVOTE | Swagger API文档")//描述 .contact("BEATREE")//作者信息 .version("1.0.0")//版本号 .build(); } }
application.yml 設定檔
swagger2: enable: false #true 启用
@Configuration 註解,指定為配置類,會在SpringBoot 啟動時進行載入。
@EnableSwagger2 註解來啟用 Swagger2。
成員方法 createRestApi 函數建立 Docket 的 Bean 之後,apiInfo() 用來創建該 Api 的基本資訊(這些基本資訊會展現在文件頁面中)。 select() 函數傳回一個 ApiSelectorBuilder 實例用來控制哪些介面暴露給 Swagger 來展現,本例採用指定掃描的套件路徑來定義,Swagger 會掃描該套件下所有 Controller 定義的 API,並產生文件內容(除了被 @ApiIgnore 指定的請求)。
常用Swagger 註解
@Api:修飾整個類,描述Controller 的作用
@ApiOperation:描述一個類別的一個方法,或者說一個介面
@ApiParam:單一參數描述@ApiModel:用物件來接收參數
@ApiProperty:用物件接收參數時,描述物件的一個欄位
@ApiResponse:HTTP 回應其中1 個描述
@ApiResponses:HTTP 回應整體描述
@ApiIgnore :使用該註解忽略這個API
@ApiError :發生錯誤回傳的訊息
@ApiImplicitParam:描述一個請求參數,可以配置參數的中文意義,也可以為參數設定預設值
@ApiImplicitParams:描述由多個
@ApiImplicitParam# 註解的參數所組成的請求參數清單
舉個栗子
@RestController @Transactional // 事务注解,实现回滚 @RequestMapping("/api/tlink") @Api(value = "/api/tlink", tags = "参与者相关接口") public class TlinkController{ @GetMapping("/checkCode/{code}") @ApiOperation(value = "投票认证码核验接口", notes = "该接口用于核验认证码合法性,对于投票主题内容的获取需后续调用Topic相关接口。返回值data中带有参数 topic & options") public JSONObject checkCode(@PathVariable("code") String code){ ... } }
最後在執行SpringBoot 專案之後,透過伺服器位址/swagger-ui.html 存取即可。
要注意的是,如已新增路徑攔截器,需透過
.excludePathPatterns("/swagger-resources/**", "/webjars/**", "/v2/**", "/swagger-ui.html/**")
對 swagger 路徑放行。
以上是SpringBoot整合Swagger2產生介面文檔,媽媽再也不用擔心我寫API文檔了的詳細內容。更多資訊請關注PHP中文網其他相關文章!

JVM'SperformanceIsCompetitiveWithOtherRuntimes,operingabalanceOfspeed,安全性和生產性。 1)JVMUSESJITCOMPILATIONFORDYNAMICOPTIMIZAIZATIONS.2)c提供NativePernativePerformanceButlanceButlactsjvm'ssafetyFeatures.3)

JavaachievesPlatFormIndependencEthroughTheJavavIrtualMachine(JVM),允許CodeTorunonAnyPlatFormWithAjvm.1)codeisscompiledIntobytecode,notmachine-specificodificcode.2)bytecodeisisteredbytheybytheybytheybythejvm,enablingcross-platerssectectectectectross-eenablingcrossectectectectectection.2)

TheJVMisanabstractcomputingmachinecrucialforrunningJavaprogramsduetoitsplatform-independentarchitecture.Itincludes:1)ClassLoaderforloadingclasses,2)RuntimeDataAreafordatastorage,3)ExecutionEnginewithInterpreter,JITCompiler,andGarbageCollectorforbytec

JVMhasacloserelationshipwiththeOSasittranslatesJavabytecodeintomachine-specificinstructions,managesmemory,andhandlesgarbagecollection.ThisrelationshipallowsJavatorunonvariousOSenvironments,butitalsopresentschallengeslikedifferentJVMbehaviorsandOS-spe

Java實現“一次編寫,到處運行”通過編譯成字節碼並在Java虛擬機(JVM)上運行。 1)編寫Java代碼並編譯成字節碼。 2)字節碼在任何安裝了JVM的平台上運行。 3)使用Java原生接口(JNI)處理平台特定功能。儘管存在挑戰,如JVM一致性和平台特定庫的使用,但WORA大大提高了開發效率和部署靈活性。

JavaachievesPlatFormIndependencethroughTheJavavIrtualMachine(JVM),允許Codetorunondifferentoperatingsystemsswithoutmodification.thejvmcompilesjavacodeintoplatform-interploplatform-interpectentbybyteentbytybyteentbybytecode,whatittheninternterninterpretsandectectececutesoneonthepecificos,atrafficteyos,Afferctinginginginginginginginginginginginginginginginginginginginginginginginginginginginginginginginginginginginginginginginginginginging

JavaispoperfulduetoitsplatFormitiondence,對象與偏見,RichstandardLibrary,PerformanceCapabilities和StrongsecurityFeatures.1)Platform-dimplighandependectionceallowsenceallowsenceallowsenceallowsencationSapplicationStornanyDevicesupportingJava.2)

Java的頂級功能包括:1)面向對象編程,支持多態性,提升代碼的靈活性和可維護性;2)異常處理機制,通過try-catch-finally塊提高代碼的魯棒性;3)垃圾回收,簡化內存管理;4)泛型,增強類型安全性;5)ambda表達式和函數式編程,使代碼更簡潔和表達性強;6)豐富的標準庫,提供優化過的數據結構和算法。


熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

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

熱門文章

熱工具

WebStorm Mac版
好用的JavaScript開發工具

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

MantisBT
Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

SublimeText3漢化版
中文版,非常好用

ZendStudio 13.5.1 Mac
強大的PHP整合開發環境