我的第一個netcore2.2 api項目搭建(三)續

来源:https://www.cnblogs.com/sy-ds/archive/2019/05/10/10838223.html
-Advertisement-
Play Games

上一章快速陳述了自定義驗證功能添加的過程,我的第一個netcore2.2 api項目搭建(三) 但是並沒有真正的去實現,這一章將要實現驗證功能的添加。 這一章實現目標三:jwt認證授權添加 在netcore2.2中,只要添加很簡單的配置就能添加jwt功能了。至於jwt本身是啥大家自行去瞭解,這裡不做 ...


上一章快速陳述了自定義驗證功能添加的過程,我的第一個netcore2.2 api項目搭建(三)

但是並沒有真正的去實現,這一章將要實現驗證功能的添加。

這一章實現目標三:jwt認證授權添加

在netcore2.2中,只要添加很簡單的配置就能添加jwt功能了。至於jwt本身是啥大家自行去瞭解,這裡不做多說了。。

1.1添加JwtHelper類

public class JwtHelper
    {
        public const string Audience = "JH.OPEMR.API";
        public const string Issuer = "all";
        public const string SigningKey = "my first security key";

        public static string CreateJwtToken(string uid, string uName, string sub)
        {
            var dateTime = DateTime.UtcNow;
            var key = new SymmetricSecurityKey(Encoding.UTF8.GetBytes(SigningKey));

            var tokenHandler = new JwtSecurityTokenHandler();
            var tokenDescriptor = new SecurityTokenDescriptor
            {
                Subject = new ClaimsIdentity(new Claim[]
               {
                    new Claim(JwtClaimTypes.Audience,Audience),
                    new Claim(JwtClaimTypes.Issuer,Issuer),
                    new Claim(JwtClaimTypes.Id, uid),
                    new Claim(JwtClaimTypes.Name, uName),
                    new Claim("Role", sub)//高亮,很重要
               }),
                Expires = dateTime.AddHours(0.5),
                SigningCredentials = new SigningCredentials(key, SecurityAlgorithms.HmacSha256Signature)
            };
            var token = tokenHandler.CreateToken(tokenDescriptor);
            var tokenString = tokenHandler.WriteToken(token);
            return tokenString;
        }
    }

這個類就一個方法,提供生成加密的jwt串

1.2在Startup做配置:

//註冊預設認證方式,這裡使用jwt方式
            services.AddAuthentication(x =>
            {
                x.DefaultAuthenticateScheme = JwtBearerDefaults.AuthenticationScheme;
                x.DefaultChallengeScheme = JwtBearerDefaults.AuthenticationScheme;
            }).AddJwtBearer(o =>
               {
                   o.TokenValidationParameters = new TokenValidationParameters
                   {
                       RoleClaimType = JwtClaimTypes.Role,//這個很重要

                       ValidIssuer = JwtHelper.Issuer,
                       ValidAudience = JwtHelper.Audience,
                       IssuerSigningKey = new SymmetricSecurityKey(Encoding.ASCII.GetBytes(JwtHelper.SigningKey))

                       /***********************************TokenValidationParameters的參數預設值***********************************/
                       // RequireSignedTokens = true,
                       // SaveSigninToken = false,
                       // ValidateActor = false,
                       // 將下麵兩個參數設置為false,可以不驗證Issuer和Audience,但是不建議這樣做。
                       // ValidateAudience = true,
                       // ValidateIssuer = true, 
                       // ValidateIssuerSigningKey = false,
                       // 是否要求Token的Claims中必須包含Expires
                       // RequireExpirationTime = true,
                       // 允許的伺服器時間偏移量
                       // ClockSkew = TimeSpan.FromSeconds(300),
                       // 是否驗證Token有效期,使用當前時間與Token的Claims中的NotBefore和Expires對比
                       // ValidateLifetime = true
                   };
               });

可以看出,JwtHelper里的幾個變數在Startup中也使用了,這樣就保證了配置的參數和生成jwt串的參數保持了一致,這樣就能起到防偽作用了,不是千千萬萬個jwt串在咱系統都能通過,如果都通過了,那不是搞笑麽。。。

1.3啟用驗證

public void Configure(IApplicationBuilder app, IHostingEnvironment env)
        {
            if (env.IsDevelopment())
            {
                app.UseDeveloperExceptionPage();
            }
        //啟用驗證
            app.UseAuthentication();

            //啟用驗證中間件
            //app.UseMiddleware<MyAutoMiddleware>();

            //啟用Swagger
            app.UseSwagger();
            app.UseSwaggerUI(options =>
            {
                options.SwaggerEndpoint("/swagger/v1/swagger.json", "My API V1");

            });

            app.UseMvc();
        }

在前一章中,咱們並沒有調用app.UseAuthentication(),是因為上一章咱們自己啟用了中間件,並沒有啟用2.2註入的驗證方式。而這一章,咱們註入了jwt,就得調用這句話是執行驗證授權了。一旦啟用,jwt就會自行進行請求的驗證功能,不需要咱們在寫代碼了。。。

ok,F5運行

可以看到,未驗證,調用失敗。。

咱們先用postman調用login模擬登錄,生成一個jwt串,代碼很簡單:

/// <summary>
    /// Account 模塊
    /// </summary>
    [Route("api/[controller]/[action]")]
    [ApiController]
    public class AccountController : ControllerBase
    {
        [HttpGet]
        public ActionResult<string> Login(long Uid, string UName, string Sub)
        {
            if (string.IsNullOrWhiteSpace(Uid.ToString()) || string.IsNullOrWhiteSpace(UName)) throw new Exception("填寫正確用戶");

            var tokenString = JwtHelper.CreateJwtToken(Uid.ToString(), UName, Sub);

            return tokenString;
        }
    }

這裡我們得到jwt字元串,將這個字元串添加到header中,再用postman調用get試試:

Headers添加 Authorization ,值:Bearer +jwt串,在Bearer後有個空格記住。

ok了,是不是很簡單,到這裡jwt簡單的認證授權其實已經加完了,後面可以根據各種許可權去維護就好了。。。

至此,第三個目標完成!

 既然添加了認證授權,那麼第二章swagger部分就得也加入該功能了,這個很簡單,只要在swagger里做配置就ok了。

//添加header身份驗證信息
                var security = new Dictionary<string, IEnumerable<string>> { { "Bearer", new string[] { } }, };
                options.AddSecurityRequirement(security);
                options.AddSecurityDefinition("Bearer", new ApiKeyScheme
                {
                    Description = "JWT授權(數據將在請求頭中進行傳輸) 參數結構: \"Authorization: Bearer {token}\"",
                    Name = "Authorization",//jwt預設的參數名稱
                    In = "header",
                    Type = "apiKey"
                });

F5運行,可以看見加了鎖

點擊Authorize,然後配置下:

再來調用get:

調用成功,可以看到header發送了剛剛添加的jwt串。

至此,整個netcore api項目簡單搭建已經完成!

不過,按這種驗證寫法,突然想到,如果前端被劫持了jwt串,然後其他應用在此jwt串有效期內利用該jwt串調用api,不是也能調通嗎??如果這樣,不是很危險嗎,竟然被別人給瞎調用了,這裡留下了深深的思考,不知道大家都是怎麼做的。。知情者可否留下解決方式,膜拜!!!

 


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

-Advertisement-
Play Games
更多相關文章
  • 上一篇博客已經完成 C#ModBus Tcp Master的實現 本篇主要對不同的功能碼所發出的報文進行解析(包括請求報文及響應報文) 讀操作 功能碼 0x01 讀一組線圈 讀取站號為1 從地址12開始的10個線圈 測試結果 上一篇博客已經總結了讀操作報文格式,就按照格式劃分 報文解析: 註意:報文 ...
  • wpf 模擬抖音很火的羅盤時鐘,附源碼 前端時間突然發現,抖音火了個壁紙,就是黑底蕾絲~~~ 錯錯錯,黑底白字的羅盤時鐘! 作為程式員的我,也覺得很新穎,所以想空了研究下,這不,空下來了就用wpf,寫個屬於.net自己的羅盤時鐘,目前只實現了時分秒,農曆日期等邏輯都是一樣的,所以就略了,有興趣的朋友 ...
  • 簡介 主要是採用identity Server4 和ocelot 加上consul 實現簡單的客戶端模式 開發準備 環境準備 下載並安裝Consul具體請參考前幾篇的內容 項目介紹 創建ocelotServerTest項目 創建IdentityServer4Test項目 創建consulServer ...
  • 什麼是options請求 options請求為發送非簡單跨域請求前的預檢請求,若該請求未正常返回,瀏覽器會阻止後續的請求發送。 一般情況下,有三種方式會導致瀏覽器發起預檢請求 1.請求的方法不是GET/HEAD/POST 2.POST請求的Content Type並非application/x ww ...
  • .NET Core 常用第三方包 作者:高堂 原文地址:https://www.cnblogs.com/gaotang/p/10845370.html 寫在前面 最近在學習.NET Core 中經常用到的一些插件,在此做個整理備忘。 Autofac "Autofac" Alexinea.Autofa ...
  • Split是string中非常有趣的命令,它是用來分隔字元串中子字元串的字元數組,並且不包含分隔符的空數組或null,如下麵的代碼: String value = "This is a short string."; Char delimiter = ' '; String[] substrings ...
  • 業務場景:有主表、子表兩個GridView點擊主表的行,會自動讀取主表對應的子表數據但是如果反覆點擊會導致反覆讀取,其實反覆點擊的時候只需要最後一次執行查詢,前面的幾次點擊都是無意義操作根據這一需求設計了一個函數:private static List Tup = new List();/// //... ...
  • 一、Excel理論知識 最新版NPOI2.4.1鏈接:https://pan.baidu.com/s/1iTgJi2hGsRQHyw2S_4dIUw 提取碼:adnq • 整個Excel表格叫做工作簿:WorkBook • 工作簿由以下幾部分組成 a.頁(Sheet); b.行(Row); c.單元 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...