ASP.NetCore使用Swagger實(shí)戰(zhàn)
踩坑不背鍋,.NET Core 試深淺 關(guān)于Swagger什么是swagger所帶來(lái)的幫助 使用Swagger
關(guān)于Swagger
什么是swagger
使人和計(jì)算機(jī)在看不到源碼或者看不到文檔或者不能通過(guò)網(wǎng)絡(luò)流量檢測(cè)的情況下能發(fā)現(xiàn)和理解各種服務(wù)的功能。
Swagger™ 的目標(biāo)是為 REST APIs 定義一個(gè)標(biāo)準(zhǔn)的,與語(yǔ)言無(wú)關(guān)的接口。只需要按照它的規(guī)范去定義接口及接口相關(guān)的信息。再通過(guò)Swagger衍生出來(lái)的一系列項(xiàng)目和工具,就可以做到生成各種格式的接口文檔,生成多種語(yǔ)言的客戶端和服務(wù)端的代碼,以及在線接口調(diào)試頁(yè)面等。
所帶來(lái)的幫助
當(dāng)項(xiàng)目處于啟動(dòng)階段
如果有了穩(wěn)定的后臺(tái)框架,直接依據(jù)業(yè)務(wù)需求編寫服務(wù)端被調(diào)用層的代碼(即controller及其入?yún)⒊鰠?duì)象),然后通過(guò)Swagger生成相關(guān)描述文件,使用者就可以直接使用了。
如果后臺(tái)框架不成熟或在設(shè)計(jì)中,但是依據(jù)業(yè)務(wù)需求我們可以完成更多的工作而不是等待,先根據(jù)數(shù)據(jù)需求編寫Swagger描述文件,通過(guò)該描述文件生成接口文檔,指引項(xiàng)目的相關(guān)開發(fā)。
當(dāng)項(xiàng)目處于迭代階段
在項(xiàng)目的持續(xù)開發(fā)中,后端人員無(wú)需關(guān)注Swagger描述文件和接口文檔,有需求變更導(dǎo)致接口變化,可直接編程實(shí)現(xiàn),然后生成新的描述文件和接口文檔后,給到前端即可。
使用Swagger
首先,先創(chuàng)建一個(gè)新的WebAPI項(xiàng)目,并在Nuget中找到對(duì)應(yīng)的包,搜索Swashbuckle會(huì)出現(xiàn)很多應(yīng)用包,可以根據(jù)描述選擇自己需要的引用。我在這里使用的是Swashbuckle.AspNetCore.Filters
接下來(lái)在Startup中插入如下代碼
注冊(cè)服務(wù)
services.AddSwaggerGen(options => { options.SwaggerDoc("v1", new OpenApiInfo { Title = "HTTP API 目錄", Version = "v1", Description = "目錄微服務(wù)HTTP API。" }); });
中間件
//啟用中間件服務(wù)生成Swagger作為JSON終結(jié)點(diǎn) app.UseSwagger(); //啟用中間件服務(wù)對(duì)swagger-ui,指定Swagger JSON終結(jié)點(diǎn) app.UseSwagger().UseSwaggerUI(c => { c.SwaggerEndpoint("/swagger/v1/swagger.json", "My API V1"); });
然后,就可以使用了,請(qǐng)求對(duì)應(yīng)地址 https://localhost:44375/swagger/index.html,現(xiàn)在就可以看到示例代碼中的WeatherForecast.cs了。
到此這篇關(guān)于ASP.NetCore使用Swagger實(shí)戰(zhàn)的文章就介紹到這了,更多相關(guān)ASP.NetCore使用Swagger內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
ASP.NET過(guò)濾HTML標(biāo)簽只保留換行與空格的方法
這篇文章主要介紹了ASP.NET過(guò)濾HTML標(biāo)簽只保留換行與空格的方法,包含網(wǎng)上常見的方法以及對(duì)此方法的改進(jìn),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2014-12-12.Net?Api?中使用Elasticsearch存儲(chǔ)文檔的方法
Elasticsearch 是一個(gè)分布式、高擴(kuò)展、高實(shí)時(shí)的搜索與數(shù)據(jù)分析引擎,在C# 的環(huán)境中,有一個(gè)Es的官方拓展包Nest,可以讓我們方便快捷的使用上Es數(shù)據(jù)庫(kù),本文重點(diǎn)給大家介紹.Net?Api?中使用Elasticsearch存儲(chǔ)文檔的方法,感興趣的朋友一起看看吧2022-01-01ASP.NET Core 實(shí)現(xiàn)基本認(rèn)證的示例代碼
這篇文章主要介紹了ASP.NET Core 實(shí)現(xiàn)基本認(rèn)證的示例代碼嗎,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-10-10asp.net運(yùn)算符之邏輯運(yùn)算符以及其他運(yùn)算符介紹與實(shí)例
在.net中運(yùn)算符分類很多種類型,包括有我們常用的boolean型運(yùn)算符,通用的運(yùn)行符有 ==、!=、<、>、<=、>=、binary +、binary -、^、&、|、~、++、-- 和 sizeof()2013-08-08ASP.NET Core中使用xUnit進(jìn)行單元測(cè)試
這篇文章主要介紹了ASP.NET Core中使用xUnit進(jìn)行單元測(cè)試,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-11-11.NET 6開發(fā)TodoList應(yīng)用之實(shí)現(xiàn)查詢排序
這篇文章主要介紹了如何通過(guò).NET 6實(shí)現(xiàn)查詢排序功能,文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí).NET 6有一定的幫助,感興趣的同學(xué)可以了解一下2022-01-01NET Core TagHelper實(shí)現(xiàn)分頁(yè)標(biāo)簽
這篇文章主要介紹了NET Core TagHelper實(shí)現(xiàn)分頁(yè)標(biāo)簽,講述實(shí)現(xiàn)一個(gè)簡(jiǎn)單分頁(yè)和總要注意步奏,感興趣的小伙伴們可以參考一下2016-07-07