Asp.Net Core2.0 WebAPI 使用Swagger生成漂亮的介面文檔

来源:https://www.cnblogs.com/NuoYer/archive/2018/01/09/8252023.html
-Advertisement-
Play Games

1、引用NuGet: Swashbuckle.AspNetCore.Swagger Swashbuckle.AspNetCore.SwaggerGen 或 2、Startup文件引用Swagger 3、對需要進行授權登錄的介面生成對應的文檔輸入框,如Bearer Token 引用該類: 4、點擊項目 ...


1、引用NuGet:

     Swashbuckle.AspNetCore.Swagger

     Swashbuckle.AspNetCore.SwaggerGen

  <PackageReference Include="Swashbuckle.AspNetCore.Swagger" Version="1.1.0" />
  <PackageReference Include="Swashbuckle.AspNetCore.SwaggerGen" Version="1.1.0" />

2、Startup文件引用Swagger

 1 services.AddSwaggerGen(options =>
 2 {
 3     options.SwaggerDoc("v1", new Info
 4     {
 5         Version = "v1",
 6         Title = "WebApi文檔"
 7     });
 8     options.OperationFilter<ApiHttpHeaderFilter>();
 9 
10     //Determine base path for the application.  
11     var basePath = PlatformServices.Default.Application.ApplicationBasePath;
12     //Set the comments path for the swagger json and ui.  
13     var xmlPath = Path.Combine(basePath, "WebApi.xml");
14     options.IncludeXmlComments(xmlPath);
15 });
1  app.UseSwagger();
2  app.UseSwaggerUI(c =>
3  {
4      c.SwaggerEndpoint("/swagger/v1/swagger.json", "WebApi文檔");
5  });

3、對需要進行授權登錄的介面生成對應的文檔輸入框,如Bearer Token   

 1 using Microsoft.AspNetCore.Authorization;
 2 using Swashbuckle.AspNetCore.Swagger;
 3 using Swashbuckle.AspNetCore.SwaggerGen;
 4 using System.Collections.Generic;
 5 using System.Linq;
 6 
 7 namespace Core.WebApi.Filters
 8 {
 9     /// <summary>
10     /// 對需要進行授權登錄的介面生成對應的文檔輸入框,如Bearer Token
11     /// </summary>
12     public class ApiHttpHeaderFilter : IDocumentFilter, IOperationFilter
13     {
14         /// <summary>
15         /// 
16         /// </summary>
17         /// <param name="operation"></param>
18         /// <param name="context"></param>
19         public void Apply(Operation operation, OperationFilterContext context)
20         {
21             operation.Parameters = operation.Parameters ?? new List<IParameter>();
22             var actionAttributes = context.ApiDescription.ActionAttributes();
23             var allowAnonymous = actionAttributes.Any(a => a.GetType() == typeof(AllowAnonymousAttribute)); // 查詢是否過濾許可權
24             if (!allowAnonymous)
25             {
26                 operation.Parameters.Add(new BodyParameter
27                 {
28                     Name = "Authorization",
29                     @In = "header",
30                     Description = "access token",
31                     Required = true
32                 });
33             }
34         }
35 
36         /// <summary>
37         /// 
38         /// </summary>
39         /// <param name="swaggerDoc"></param>
40         /// <param name="context"></param>
41         public void Apply(SwaggerDocument swaggerDoc, DocumentFilterContext context)
42         {
43             throw new System.NotImplementedException();
44         }
45     }
46 }

   引用該類:

options.OperationFilter<ApiHttpHeaderFilter>();

4、點擊項目右鍵屬性(勾選生成WebApi.xml文檔):

  

 

效果:


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

-Advertisement-
Play Games
更多相關文章
  • 1. 前言 微軟在 "Build 2017" 中公佈了新的設計語言Fluent Design System(以下簡稱FDS),不過 "官網" 只是堆砌了各種華麗的詞語以及一堆動畫。至於在UWP中要做成怎麼樣,怎麼做,可以參考這個視頻: "Build Amazing Apps with Fluent ...
  • "回到目錄" LindDotNetCore中間件 大叔認識中間件就是主要對 http請求進行攔截 ,然後添加具體個性化功能的邏輯,這種把請求切開,添加新邏輯的方式一般稱為面向方面的邏輯AOP! 1. 授權中間件 2. 請求鏈跟蹤中間件 3. 響應時間中間件 授權中間件 請求有效性的校驗 授權參數 客 ...
  • 報錯信息:The method 'Skip' is only supported for sorted input in LINQ to Entities. The method 'OrderBy' must …… EF 使用ToPagedList。 這是沒有使用OrderBy或者OrderByDe ...
  • webapi介面在ajax調用的很多情況下都會出現跨域問題,同樣的WebService如果想用ajax調用,也需要介面跨域問題,解決方案如下: 1、IIS配置 打開IIS選擇發佈後的webapi或者是WebService,選擇網站-->選擇HTTP 響應表頭-->添加。。操作如下: 需要添加的名稱和 ...
  • 1、獲取客戶端IP地址實現方法(擴展類) 調用該方法: 2、解決Asp.Net Core2.0發佈到Ubuntu後不能正確獲取客戶IP解決辦法 本人站點用的是Nginx進行代理,而站點指向是本地Ip,不能正確獲得客戶的IP,這時就需要通過Nginx獲取到的IP傳遞給站點 Nginx的配置 重啟Ngi ...
  • 一、前言 由於項目是前後端分離,API介面與Web前端 部署在不同站點當中,因此在前文當中 "WebApi Ajax 跨域請求解決方法(CORS實現)" 使用跨域處理方式處理而不用 的方式。 但是在一段時間後,發現一個很奇怪的問題,每次前端發起請求的時候,通過瀏覽器的開發者工具都能看到在 下同一個 ...
  • 1、services 2、app ...
  • 1 private string GetAccountNo() 2 { 3 try 4 { 5 string shortName="B"; 6 string latestAccountNO = shortName + "000001"; ... ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...