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

歡迎訪問 生活随笔!

生活随笔

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

asp.net

.NET6之MiniAPI(十八):OpenAPI swagger

發布時間:2023/12/4 asp.net 66 豆豆
生活随笔 收集整理的這篇文章主要介紹了 .NET6之MiniAPI(十八):OpenAPI swagger 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

從本篇開始,介紹一些很不錯的三方庫,來豐富MiniAPI的使用。

在創建MiniAPI項目時,模板提供了一個是否啟用OpenAPI的選項,足見這個三方庫的優勢和強大。

OpenAPI為我們測試API提供了強大的支持,調用API的開發人員,可以輕松測試,參照開發接口和接口參數,有效的節省了大量文檔的書寫和調試流程復雜性。

為了更好的說明,需要開啟注釋文件生成功能,打開項目文件,增加GenerateDocumentdationFile節點即可。

<Project?Sdk="Microsoft.NET.Sdk.Web"><PropertyGroup><TargetFramework>net6.0</TargetFramework><Nullable>enable</Nullable><ImplicitUsings>enable</ImplicitUsings><GenerateDocumentationFile>True</GenerateDocumentationFile></PropertyGroup><ItemGroup><PackageReference Include="Swashbuckle.AspNetCore" Version="6.2.3" /></ItemGroup> </Project>

先看Swagger引入的代碼:

using Microsoft.OpenApi.Models;var builder = WebApplication.CreateBuilder(args);builder.Services.AddEndpointsApiExplorer(); builder.Services.AddSwaggerGen(c => {c.SwaggerDoc("v1",new OpenApiInfo{Title = "MiniAPI08-V1",Version = "v1"});//設置xml引用var filePath = Path.Combine(System.AppContext.BaseDirectory, "MiniAPI08.xml");c.IncludeXmlComments(filePath);//添加授權var schemeName = "Bearer";c.AddSecurityDefinition(schemeName, new OpenApiSecurityScheme{In = ParameterLocation.Header,Description = "請輸入不帶有Bearer的Token",Name = "Authorization",Type = SecuritySchemeType.Http,Scheme = schemeName.ToLowerInvariant(),BearerFormat = "JWT"});c.AddSecurityRequirement(new OpenApiSecurityRequirement {{new OpenApiSecurityScheme{Reference = new OpenApiReference{Type = ReferenceType.SecurityScheme,Id = schemeName}},new string[0]}}); });var app = builder.Build();if (app.Environment.IsDevelopment()) {app.UseSwagger();app.UseSwaggerUI(c =>{c.EnablePersistAuthorization();}); }app.MapPut("/test", (Data data) => { }) .WithName("puttest") .WithTags("all test");app.MapDelete("/test/{id}", TestHandle.DeleteTest) .WithName("deletetest") .WithTags("all test");app.MapGet("/test/{id}", (HttpRequest request, int id) => {Console.WriteLine(request.Headers["Authorization"]); }) .WithName("gettest") .WithTags("all test") .Produces<Data>(StatusCodes.Status200OK) .Produces(StatusCodes.Status404NotFound);app.MapPost("/test", (Data data) =>{}) .WithName("posttest") .WithTags("all test");app.Run();class TestHandle {/// <summary>/// 刪除Test/// </summary>/// <param name="id">Data的主鍵</param>/// <returns></returns>public static bool DeleteTest(int id){return true;} } /// <summary> /// 提交數據 /// </summary> class Data {/// <summary>/// 編號 /// </summary>public int Id { get; set; }/// <summary>/// 名稱/// </summary>public string Name { get; set; } }

Tags?是all test,可以把同類操作放在一個組里,對應著swagger的一組

現在的MiniAPI對單個請求還不支持注釋(就是get ,post,put,delete的api注釋),相信.NET 7會解決掉。

如果請求的方法是匿名方法,同樣參數也是不支持說明的,如果像delete請求,指像命名方法,方法的參數是注釋說明是會顯示在swagger里的:

如查Mini API支持Token驗證,可以通過AddSwaggerGen添加Security來實現自帶Token,具體做法見代碼實現:c.AddSecurityDefinition和 c.AddSecurityRequirement。這樣可以在Swagger頁面,點擊Authorize按鈕,輸入Token,這時,所有的請求都會帶上Authorization的header。

調用Get方法時,會自動帶上Authorization

后端會獲取到Token數據

總結

以上是生活随笔為你收集整理的.NET6之MiniAPI(十八):OpenAPI swagger的全部內容,希望文章能夠幫你解決所遇到的問題。

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

主站蜘蛛池模板: 国产综合精品一区二区三区 | 69社| 69视频一区二区三区 | 无码人妻精品一区二区三区在线 | 成人传媒 | 一区精品在线 | 少妇高潮毛片 | 成人av免费在线 | 久久在线电影 | 草av在线 | 亚洲国产一区二区在线观看 | 午夜写真片福利电影网 | 久久夜精| 国产精品高潮呻吟久久av黑人 | 99视频在线看 | 1000部多毛熟女毛茸茸 | 国产精品一区二区三 | 久久久精品日本 | 国产在线97 | 色呦呦在线看 | 午夜精品久久久 | 日本午夜激情视频 | 欧美国产专区 | 亚欧洲精品在线视频免费观看 | 国产91丝袜在线播放 | 国产精品不卡在线 | 久久片| 婷婷综合另类小说色区 | 日本三级视频 | 日韩欧美天堂 | 精品爆乳一区二区三区无码av | 欧美性受xxxxxx黑人xyx性爽 | 亚洲图片在线 | 岛国在线视频 | 国产又粗又黄视频 | 国产小视频网址 | 成人免费激情视频 | 日韩中文字幕有码 | 国产精品日日摸天天碰 | 天天碰免费视频 | 国产伦精品一区二区三区照片 | 国产淫视 | 天天天天天天天天干 | 午夜精品视频一区二区三区在线看 | 成人黄色性视频 | 91精品观看 | 男女av在线 | 女生脱裤子让男生捅 | 在线免费黄 | 亚洲88| 久久中文字幕无码 | 国产天堂网 | 日韩精品一区二区三区在线视频 | 中文字幕99页 | 超碰爱爱| 日韩欧美中文字幕精品 | 精品国产免费视频 | 亚洲在线免费看 | 精品国产三级a∨在线 | 天天视频黄 | 99国产精品99久久久久久粉嫩 | 久久嫩| 久久亚洲视频 | 超碰97在线资源站 | 天堂va欧美va亚洲va老司机 | av资源网址 | 国产原创91 | 本道久久 | 午夜av剧场 | av永久免费观看 | 一级片久久| 久久久久久国产精品一区 | 人人爽人人草 | 色呦网站 | 成人午夜在线免费观看 | 欧美另类日韩 | 欧美少妇毛茸茸 | 黄色777| 在线免费黄色av | 隔壁邻居是巨爆乳寡妇 | 老司机福利av | 日本一区久久 | 国产精品白嫩极品美女视频 | 国产美女精品在线 | xvideos成人免费视频 | 成人片黄网站色大片免费毛片 | 国产suv精品一区二区三区 | 欧美三级午夜理伦三级老人 | 好了av在线 | 国产精品一区二区黑人巨大 | 黄色一级片黄色一级片 | 欧洲亚洲一区二区 | 日本亚洲一区二区三区 | 我们的生活第五季在线观看免费 | 国产精品国产精品国产专区不片 | 亚洲成人看片 | 中文字幕免费观看视频 | 波多野结衣理论片 | 公侵犯一区二区三区 |