国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > C# > 正文

JWT.net 操作實踐方法

2020-01-24 00:22:50
字體:
來源:轉載
供稿:網友

1.JWT定義

JWT(Json Web Token)是一種用于雙方之間傳遞安全信息的簡潔的、URL安全的表述性聲明規范。JWT作為一個開放的標準( RFC 7519 ),定義了一種簡潔的,自包含的方法用于通信雙方之間以Json對象的形式安全的傳遞信息。因為數字簽名的存在,這些信息是可信的,JWT可以使用HMAC算法或者是RSA的公私秘鑰對進行簽名。

2.JWT的組成部分

(1)JWT一般由三段構成,用.號分隔開,第一段是header,第二段是payload,第三段是signature,

例如:

eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiYWRtaW4iOnRydWV9.TJVA95OrM7E2cBab30RMHrHDcEfxjoYZgeFONFh7HgQ

3.Jwt.Net 使用

首先,需要先引入Jwt.Net,可通過nuget的方式添加:Install-Package JWT -Version 2.4.2(自己選擇合適的版本)

(1)創建token,此處,我們只需要自定義payload和secrect密鑰即可,可生成三段格式的字符串

var payload = new Dictionary<string, object>{ { "claim1", 0 }, { "claim2", "claim2-value" }};var secret = "GQDstcKsx0NHjPOuXOYg5MbeJ1XT0uFiwDVvVBrk"; IJwtAlgorithm algorithm = new HMACSHA256Algorithm();IJsonSerializer serializer = new JsonNetSerializer();IBase64UrlEncoder urlEncoder = new JwtBase64UrlEncoder();IJwtEncoder encoder = new JwtEncoder(algorithm, serializer, urlEncoder); var token = encoder.Encode(payload, secret);Console.WriteLine(token);

(2)token解密,可看到輸出為{ "claim1": 0, "claim2": "claim2-value" },可以用json["claim1"],json["claim2"]的方式獲取各個值,此處json為IDictionary<string,object>類型token解密,可看到輸出為{ "claim1": 0, "claim2": "claim2-value" },可以用json["claim1"],json["claim2"]的方式獲取各個值,此處json為IDictionary<string,object>類型

var token = "eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJjbGFpbTEiOjAsImNsYWltMiI6ImNsYWltMi12YWx1ZSJ9.8pwBI_HtXqI3UgQHQ_rDRnSQRxFL1SR8fbQoS-5kM5s";var secret = "GQDstcKsx0NHjPOuXOYg5MbeJ1XT0uFiwDVvVBrk";try{ IJsonSerializer serializer = new JsonNetSerializer(); IDateTimeProvider provider = new UtcDateTimeProvider(); IJwtValidator validator = new JwtValidator(serializer, provider); IBase64UrlEncoder urlEncoder = new JwtBase64UrlEncoder(); IJwtDecoder decoder = new JwtDecoder(serializer, validator, urlEncoder);  var json = decoder.Decode(token, secret, verify: true); Console.WriteLine(json);}catch (TokenExpiredException){ Console.WriteLine("Token has expired");}catch (SignatureVerificationException){ Console.WriteLine("Token has invalid signature");}

(3)添加過期時間,過期時間即這個時間之后JWT不接受處理,時間的有效值為某一時刻和1970/1/1 00:00:00 相差的秒數

下面的例子是當前時間到1970/1/1 00:00:00 的秒數,即過期時間為當前時間。如果設置為當前時間+10秒,可添加secondsSinceEpoch=secondsSinceEpoch+10

IDateTimeProvider provider = new UtcDateTimeProvider();var now = provider.GetNow(); var unixEpoch = new DateTime(1970, 1, 1, 0, 0, 0, DateTimeKind.Utc); // or use JwtValidator.UnixEpochvar secondsSinceEpoch = Math.Round((now - unixEpoch).TotalSeconds); var payload = new Dictionary<string, object>{ { "exp", secondsSinceEpoch }};var secret = "GQDstcKsx0NHjPOuXOYg5MbeJ1XT0uFiwDVvVBrk";var token = encoder.Encode(payload, secret); var json = decoder.Decode(token, secret); // TokenExpiredException

(4)也可自定義json解析器,只要繼承IJsonSerializer接口

public class CustomJsonSerializer : IJsonSerializer{ public string Serialize(object obj) { // Implement using favorite JSON Serializer }  public T Deserialize<T>(string json) { // Implement using favorite JSON Serializer }}

使用該解析器

IJwtAlgorithm algorithm = new HMACSHA256Algorithm();IJsonSerializer serializer = new CustomJsonSerializer();IBase64UrlEncoder urlEncoder = new JwtBase64UrlEncoder();IJwtEncoder encoder = new JwtEncoder(algorithm, serializer, urlEncoder);

以上這篇JWT.net 操作實踐方法就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 乡城县| 禄丰县| 延川县| 炉霍县| 依安县| 汽车| 渝中区| 呼玛县| 界首市| 金坛市| 怀宁县| 双牌县| 南丹县| 上蔡县| 钟祥市| 太仆寺旗| 东丰县| 白河县| 宁城县| 平南县| 庆城县| 罗源县| 广州市| 麻栗坡县| 柳林县| 延边| 中卫市| 南郑县| 正阳县| 龙江县| 富平县| 政和县| 大埔区| 中西区| 鹰潭市| 紫阳县| 阿勒泰市| 永和县| 新民市| 兴城市| 伊金霍洛旗|