網站首頁 編程語言 正文
什么是JWT,它是一種對API的保護方案,為什么要進行保護呢
- 防泄漏:你肯定不希望你的數據能被別人隨意調用,比如公司的機密信息,不可能每個人都可以訪問到
- 防攻擊:防止被人偽裝惡意調用接口,利用網關就把請求攔截在外面,防止對服務器造成資源壓力
- 防止被人篡改,導致請求不到信息,防重放攻擊(案例:在公共網絡環境中,請求被截獲,稍后被重放或多次重放)
設計原則
- 輕量級
- 易于開發、測試和部署
- 適合于異構系統(跨操作系統、多語言簡易實現)
- 所有寫操作接口(增、刪、改 操作)
- 非公開的讀接口(如:涉密/敏感/隱私 等)
第一步:創建token
///? ? ? ? /// 創建token ? ? ? ? /// ? ? ? ? ///? ? ? ? [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
///? ? ? ? /// 解析token ? ? ? ? /// ? ? ? ? /// ? ? ? ? ///? ? ? ? [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 }); ? ? ? ? }
原文鏈接:https://blog.csdn.net/weixin_46942018/article/details/122302408
相關推薦
- 2022-09-17 ASP.NET?Core項目中集成TypeScript_實用技巧
- 2022-07-10 oracle中的session
- 2022-09-09 python中字符串的常見操作總結(一)_python
- 2022-12-03 Flutter狀態管理Bloc使用示例詳解_Android
- 2022-12-24 詳解C#?parallel中并行計算的四種寫法總結_C#教程
- 2022-10-01 C#?將?Stream?保存到文件的方法_C#教程
- 2022-06-28 React18之狀態批處理的使用_React
- 2022-07-29 Jetpack?Compose實現列表和動畫效果詳解_Android
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支