免费A级毛片无码专区网站-成人国产精品视频一区二区-啊 日出水了 用力乖乖在线-国产黑色丝袜在线观看下-天天操美女夜夜操美女-日韩网站在线观看中文字幕-AV高清hd片XXX国产-亚洲av中文字字幕乱码综合-搬开女人下面使劲插视频

包含hmac-based和public-key emqx啟用JWT令牌認證

emqx連接啟用jwt令牌認證jwt令牌概述JWT 即 JSON Web Tokens是一種開放的,用于在兩方之間安全地表示聲明的行業(yè)標準的方法(RFC 7519) 。
組成令牌的形式 xxx.yyy.zzz
eyJhbGciOiJIUzI1NiJ9.eyJleHAiOjE2NjU0Nzc4NjEsInVzZXIiOiJtcXR0LWNsaWVudCIsImlhdCI6MTY2NTQ3Njg2MX0.S9ZrrAk2zmUC2zQ7YNcGwhojLOKV5Bhe3zrMv6rQuzE由三部分組成,先后分別為HEADER、PAYLOAD、VERIFY SIGNATURE簡單的說,xxx和yyy是對JSON字符串進行base64加密得到,zzz是由“xxx.yyy”加密得到,最后組裝成 xxx.yyy.zzz
HEADERHEADER(頭部)由 ALGORITHM(算法) 和 TOKEN TYPE(令牌類型) 組成
{  "alg": "HS256",  "typ": "JWT"}xxx由HEADER使用Base64加密得到alg : 表示簽名的算法typ : 表示令牌的類型
PAYLOAD【包含hmac-based和public-key emqx啟用JWT令牌認證】PAYLOAD(負載)存放一些用戶信息,但不能存放敏感信息,因為負載中的信息是公開的yyy由PAYLOAD使用Base64加密得到
VERIFY SIGNATUREVERIFY SIGNATURE(驗證簽名)zzz由前兩部分使用簽名加密得到,即對 xxx.yyy 加密,中間連接的“.”是需要的
生成JWT依賴        <dependency>            <groupId>io.jsonwebtoken</groupId>            <artifactId>jjwt</artifactId>            <version>0.6.0</version>        </dependency>代碼

api使用方式是生成JwtBuilder對象 然后調(diào)用compact()方法,就能得到JWT.JWT主要由三部分組成,那么代碼中同理需要對三部分進行構(gòu)造,使用api時,主要是對PAYLOAD和VERIFY SIGNATURE進行賦值.
        Instant now = Instant.now();        Map<String, Object> claims = new HashMap<>();        claims.put("user", "mqtt-client");        String compact = Jwts.builder()                .setClaims(claims) // 自定義聲明                .setIssuedAt(Date.from(now)) // 對標準中的聲明賦值,設(shè)置簽發(fā)時間                .setExpiration(Date.from(now.plusSeconds(1000))) // 對標準中的聲明賦值,設(shè)置過期時間                .signWith(SignatureAlgorithm.HS256, "NmVlR3l2T3BiQnBXMi9veVBlcTZWaEpES09XTzdoWnM=") // 設(shè)置簽名                .compact();        System.out.println(compact);tips
  1. 值得注意的一點是:不要在 setXxx(標準中的聲明) 之后調(diào)用 setClaims,因為這兩個方法會覆蓋所有已設(shè)置的聲明
  2. PAYLOAD可以分為payload和claims,但是兩者既不能都為空也不能都存在,同時只能存在一個,否則將會報錯.
    包含hmac-based和public-key emqx啟用JWT令牌認證

    文章插圖
  3. 可以不手動設(shè)置HEADER,api中會自動設(shè)置,當(dāng)然,自己手動設(shè)置HEADER屬性也可以
  4. HEADER中的alg會隨構(gòu)造的簽名自動變更
  5. 關(guān)于默認的claims
根據(jù)RFC 7519協(xié)議標準 我們獲取到JWT標準中claims的字段,這些字段是可選的

經(jīng)驗總結(jié)擴展閱讀