zoukankan      html  css  js  c++  java
  • JWT Claims

    JWT Claims

    “iss” (issuer)  发行人

    “sub” (subject)  主题

    “aud” (audience) 接收方 用户

    “exp” (expiration time) 到期时间

    “nbf” (not before)  在此之前不可用

    “iat” (issued at)  jwt的签发时间

    “jti” (JWT ID)  jwt的唯一身份标识,主要用来作为一次性token,从而回避重放攻击。

      /// <summary>
      ///   JSON Web Token (JWT) claims set.
      /// </summary>
      TJWTClaims = class(TJOSEBase)
      private
        const AUDIENCE_SEPARATOR = ',';
      private
        function GetAudience: string;
        function GetExpiration: TDateTime;
        function GetIssuedAt: TDateTime;
        function GetIssuer: string;
        function GetJWTId: string;
        function GetNotBefore: TDateTime;
        function GetSubject: string;
        procedure SetAudience(Value: string);
        procedure SetExpiration(Value: TDateTime);
        procedure SetIssuedAt(Value: TDateTime);
        procedure SetIssuer(Value: string);
        procedure SetJWTId(Value: string);
        procedure SetNotBefore(Value: TDateTime);
        procedure SetSubject(Value: string);
    
        function GetHasAudience: Boolean;
        function GetHasExpiration: Boolean;
        function GetHasIssuedAt: Boolean;
        function GetHasIssuer: Boolean;
        function GetHasJWTId: Boolean;
        function GetHasNotBefore: Boolean;
        function GetHasSubject: Boolean;
    
        function ClaimExists(const AClaimName: string): Boolean;
        function GetAudienceArray: TArray<string>;
        procedure SetAudienceArray(const Value: TArray<string>);
      public
        constructor Create; virtual;
        procedure SetClaimOfType<T>(const AName: string; const AValue: T);
        function GenerateJWTId(ANumberOfBytes: Integer = 16): string;
    
        property Audience: string read GetAudience write SetAudience;
        property AudienceArray: TArray<string> read GetAudienceArray write SetAudienceArray;
        property HasAudience: Boolean read GetHasAudience;
        property Expiration: TDateTime read GetExpiration write SetExpiration;
        property HasExpiration: Boolean read GetHasExpiration;
        property IssuedAt: TDateTime read GetIssuedAt write SetIssuedAt;
        property HasIssuedAt: Boolean read GetHasIssuedAt;
        property Issuer: string read GetIssuer write SetIssuer;
        property HasIssuer: Boolean read GetHasIssuer;
        property JWTId: string read GetJWTId write SetJWTId;
        property HasJWTId: Boolean read GetHasJWTId;
        property NotBefore: TDateTime read GetNotBefore write SetNotBefore;
        property HasNotBefore: Boolean read GetHasNotBefore;
        property Subject: string read GetSubject write SetSubject;
        property HasSubject: Boolean read GetHasSubject;
      end;
    

      

  • 相关阅读:
    腾讯会议API接入
    解决远程调用三方接口:javax.net.ssl.SSLHandshakeException报错
    iOS自动创建本地化文件
    数组转换
    2021MongoDB技术实践与应用案例征集活动获奖通知
    MongoDB按需物化视图介绍
    参会指南 | 2021MongoDB南京技术沙龙
    叮咚买菜自建MongoDB上云实践
    MongoDB技术实践与应用案例征集中
    使用WT工具恢复MongoDB数据
  • 原文地址:https://www.cnblogs.com/hnxxcxg/p/11367704.html
Copyright © 2011-2022 走看看