欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C#?JWT權(quán)限驗(yàn)證的實(shí)現(xiàn)

 更新時(shí)間:2022年03月22日 10:56:40   作者:幸福簡(jiǎn)單2020  
本文主要介紹了C#?JWT權(quán)限驗(yàn)證的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

什么是JWT,它是一種對(duì)API的保護(hù)方案,為什么要進(jìn)行保護(hù)呢

  • 防泄漏:你肯定不希望你的數(shù)據(jù)能被別人隨意調(diào)用,比如公司的機(jī)密信息,不可能每個(gè)人都可以訪問(wèn)到
  • 防攻擊:防止被人偽裝惡意調(diào)用接口,利用網(wǎng)關(guān)就把請(qǐng)求攔截在外面,防止對(duì)服務(wù)器造成資源壓力
  • 防止被人篡改,導(dǎo)致請(qǐng)求不到信息,防重放攻擊(案例:在公共網(wǎng)絡(luò)環(huán)境中,請(qǐng)求被截獲,稍后被重放或多次重放)

設(shè)計(jì)原則

  • 輕量級(jí)
  • 易于開發(fā)、測(cè)試和部署
  • 適合于異構(gòu)系統(tǒng)(跨操作系統(tǒng)、多語(yǔ)言簡(jiǎn)易實(shí)現(xiàn))
  • 所有寫操作接口(增、刪、改 操作)
  • 非公開的讀接口(如:涉密/敏感/隱私 等)

第一步:創(chuàng)建token

/// <summary>
? ? ? ? /// 創(chuàng)建token
? ? ? ? /// </summary>
? ? ? ? /// <returns></returns>
? ? ? ? [HttpPost]
? ? ? ? public IActionResult CreateJWT1()
? ? ? ? {
? ? ? ? ? ? //創(chuàng)建聲明Token數(shù)組
? ? ? ? ? ? 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"));//密鑰大小要超過(guò)128bt,最少要16位

? ? ? ? ? ? //實(shí)例化一個(gè)token對(duì)象
? ? ? ? ? ? //第一種方式
? ? ? ? ? ? //var token = new JwtSecurityToken(claims: claim);

? ? ? ? ? ? //第二種方式
? ? ? ? ? ? var token = new JwtSecurityToken(
? ? ? ? ? ? ? ? issuer: "kevin",//發(fā)起人:當(dāng)前項(xiàng)目
? ? ? ? ? ? ? ? audience: "kevin project",//訂閱:我們需要誰(shuí)去使用這個(gè)Token
? ? ? ? ? ? ? ? claims: claim,//聲明的數(shù)組
? ? ? ? ? ? ? ? expires: DateTime.Now.AddHours(1),//當(dāng)前時(shí)間加一小時(shí),一小時(shí)后過(guò)期
? ? ? ? ? ? ? ? signingCredentials: new SigningCredentials(key, SecurityAlgorithms.HmacSha256)//數(shù)字簽名 第一部分是密鑰,第二部分是加密方式
? ? ? ? ? ? ? ? );

? ? ? ? ? ? //生成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 });
? ? ? ? }

到此這篇關(guān)于C# JWT權(quán)限驗(yàn)證的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)C# JWT權(quán)限驗(yàn)證內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C#中async和await的深入分析

    C#中async和await的深入分析

    Async/Await是C# 5引入的關(guān)鍵字,用以提高用戶界面響應(yīng)能力和對(duì)Web資源的訪問(wèn)能力,同時(shí)它使異步代碼的編寫變得更加容易,下面這篇文章主要給大家介紹了關(guān)于C#中async和await的相關(guān)資料,需要的朋友可以參考下
    2022-11-11
  • Unity命令行打包WebGL的示例代碼

    Unity命令行打包WebGL的示例代碼

    這篇文章主要介紹了Unity命令行打包WebGL的相關(guān)知識(shí),本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-02-02
  • c# 將Datatable數(shù)據(jù)導(dǎo)出到Excel表格中

    c# 將Datatable數(shù)據(jù)導(dǎo)出到Excel表格中

    本文主要介紹了c# 將Datatable數(shù)據(jù)導(dǎo)出到Excel表格中的方法。具有很好的參考價(jià)值。下面跟著小編一起來(lái)看下吧
    2017-03-03
  • Untiy Shader實(shí)現(xiàn)紋理貼圖滾動(dòng)

    Untiy Shader實(shí)現(xiàn)紋理貼圖滾動(dòng)

    這篇文章主要為大家詳細(xì)介紹了Untiy Shader實(shí)現(xiàn)紋理貼圖滾動(dòng),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-03-03
  • 深入C#任務(wù)管理器中應(yīng)用程序選項(xiàng)隱藏程序本身的方法詳解

    深入C#任務(wù)管理器中應(yīng)用程序選項(xiàng)隱藏程序本身的方法詳解

    本篇文章是對(duì)在C#任務(wù)管理器中應(yīng)用程序選項(xiàng)隱藏程序本身的方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-05-05
  • C#操作windows注冊(cè)表的方法

    C#操作windows注冊(cè)表的方法

    這篇文章主要介紹了C#操作windows注冊(cè)表的方法,涉及C#針對(duì)注冊(cè)表的讀取與寫入技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下
    2015-04-04
  • C#集合本質(zhì)之鏈表的用法詳解

    C#集合本質(zhì)之鏈表的用法詳解

    本文詳細(xì)講解了C#集合本質(zhì)之鏈表的用法,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-08-08
  • C# WinForm制作異形窗體與控件的方法

    C# WinForm制作異形窗體與控件的方法

    這篇文章主要介紹了C# WinForm制作異形窗體與控件的方法,結(jié)合實(shí)例形式分析了WinForm制作異形窗體與控件的原理、實(shí)現(xiàn)步驟與相關(guān)操作技巧,需要的朋友可以參考下
    2017-05-05
  • C#實(shí)現(xiàn)貝塞爾曲線的方法

    C#實(shí)現(xiàn)貝塞爾曲線的方法

    這篇文章主要為大家詳細(xì)介紹了C#實(shí)現(xiàn)貝塞爾曲線的方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • c#操作附加數(shù)據(jù)庫(kù)的方法

    c#操作附加數(shù)據(jù)庫(kù)的方法

    這篇文章主要介紹了c#操作附加數(shù)據(jù)庫(kù)的方法,涉及C#針對(duì)附加數(shù)據(jù)庫(kù)的相關(guān)操作技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-08-08

最新評(píng)論