日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > asp.net >内容正文

asp.net

ASP.NET Core Web API使用静态swagger.json文件

發布時間:2023/12/4 asp.net 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 ASP.NET Core Web API使用静态swagger.json文件 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

前言

ASP.NET Core Web API默認集成了Swashbuckle,可以在運行時顯示Swagger UI:

而Swagger UI實際上是解析的動態生成的swagger.json:

app.UseSwagger(); app.UseSwaggerUI(c?=>?c.SwaggerEndpoint("/swagger/v1/swagger.json",?"WebApplication3?v1"));

其實,部署ASP.NET Core Web API完成后,swagger.json的內容就不會改變了,完全可以用靜態文件替代。

實現

創建ASP.NET Core Web API項目,然后安裝Swashbuckle CLI:

dotnet?tool?install?SwashBuckle.AspNetCore.Cli

1.生成靜態文件

引用Nuget包Swashbuckle.AspNetCore.Annotations,并在項目下創建wwwroot\swagger\v1目錄,然后編寫生成后事件命令行:

dotnet?swagger?tofile?--output?./wwwroot/swagger/v1/swagger.json?$(OutputPath)$(AssemblyName).dll?v1

這樣,每次編譯項目,就會在目錄下生成swagger.json靜態文件。

2.使用靜態文件

修改Startup.cs:

//app.UseSwagger(); app.UseStaticFiles(); app.UseSwaggerUI(c?=>?c.SwaggerEndpoint("/swagger/v1/swagger.json",?"WebApplication3?v1"));

可以看到,我們注釋掉了app.UseSwagger(),這會移除SwaggerMiddleware,不會再在運行時生成swagger.json。

運行程序,訪問Swagger UI,和以前沒有任何區別。

結論

相對于運行時生成swagger.json,靜態文件性能更好,而且方便提供給第三方。

如果你覺得這篇文章對你有所啟發,請關注我的個人公眾號”My IO“

總結

以上是生活随笔為你收集整理的ASP.NET Core Web API使用静态swagger.json文件的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。