首頁 > 軟體

C# JWT許可權驗證的實現

2022-03-22 13:01:00

什麼是JWT,它是一種對API的保護方案,為什麼要進行保護呢

  • 防洩漏:你肯定不希望你的資料能被別人隨意呼叫,比如公司的機密資訊,不可能每個人都可以存取到
  • 防攻擊:防止被人偽裝惡意呼叫介面,利用閘道器就把請求攔截在外面,防止對伺服器造成資源壓力
  • 防止被人篡改,導致請求不到資訊,防重放攻擊(案例:在公共網路環境中,請求被截獲,稍後被重放或多次重放)

設計原則

  • 輕量級
  • 易於開發、測試和部署
  • 適合於異構系統(跨作業系統、多語言簡易實現)
  • 所有寫操作介面(增、刪、改 操作)
  • 非公開的讀介面(如:涉密/敏感/隱私 等)

第一步:建立token

/// <summary>
        /// 建立token
        /// </summary>
        /// <returns></returns>
        [HttpPost]
        public IActionResult CreateJWT1()
        {
            //建立宣告Token陣列
            var claim = new Claim[]
                {
                new Claim("userid","123"),
                new Claim("userCode","kevinMa"),
                new Claim("projectID","62"),
                new Claim("isValid","1"),
                new Claim("userName","馬鵬"),
                new Claim("address","深圳"),
                new Claim("datetime",DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss")),
                new Claim("expires",DateTime.Now.AddHours(1).ToString("yyyy-MM-dd HH:mm:ss")),
                };

            var key = new SymmetricSecurityKey(Encoding.UTF8.GetBytes("yanglingcong@qq.com"));//金鑰大小要超過128bt,最少要16位元

            //範例化一個token物件
            //第一種方式
            //var token = new JwtSecurityToken(claims: claim);

            //第二種方式
            var token = new JwtSecurityToken(
                issuer: "kevin",//發起人:當前專案
                audience: "kevin project",//訂閱:我們需要誰去使用這個Token
                claims: claim,//宣告的陣列
                expires: DateTime.Now.AddHours(1),//當前時間加一小時,一小時後過期
                signingCredentials: new SigningCredentials(key, SecurityAlgorithms.HmacSha256)//數位簽章 第一部分是金鑰,第二部分是加密方式
                );

            //生成token
            var jwtToken = new JwtSecurityTokenHandler().WriteToken(token);
            return ToSuccessJson(new { token = jwtToken });
        }

第二步:解析token

/// <summary>
        /// 解析token
        /// </summary>
        /// <param name="token"></param>
        /// <returns></returns>
        [HttpPost]
        public IActionResult JXToken(string token)
        {
            
            //第一種直接用JwtSecurityTokenHandler提供的read方法
            var jwtHander = new JwtSecurityTokenHandler();
            JwtSecurityToken jwtSecurityToken = jwtHander.ReadJwtToken(token);
            
            GetTokenModel tokenModel = new GetTokenModel();
            var currentInfo = jwtSecurityToken.Claims;
            if (currentInfo.Count() > 0)
            {
                tokenModel.userid = currentInfo.FirstOrDefault(f => f.Type == "userid").Value;
                tokenModel.userCode = currentInfo.FirstOrDefault(f => f.Type == "userCode").Value;
                tokenModel.projectID = currentInfo.FirstOrDefault(f => f.Type == "projectID").Value;
                tokenModel.userName = currentInfo.FirstOrDefault(f => f.Type == "userName").Value;
                tokenModel.address = currentInfo.FirstOrDefault(f => f.Type == "address").Value;
                tokenModel.datetime = currentInfo.FirstOrDefault(f => f.Type == "datetime").Value;
                tokenModel.expires = currentInfo.FirstOrDefault(f => f.Type == "expires").Value;
            }
            return ToSuccessJson(new { tokenModel });
        }

到此這篇關於C# JWT許可權驗證的實現的文章就介紹到這了,更多相關C# JWT許可權驗證內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!


IT145.com E-mail:sddin#qq.com