JWT sha256哈希与Internet草案示例不匹配

时间:2014-12-17 08:10:05

标签: javascript json google-apps-script jwt

我一直致力于让JWT在Google Apps脚本中工作。由于我的成绩不好,我去了JWS Internet-Draft: http://self-issued.info/docs/draft-ietf-jose-json-web-signature.html#HS256Encoding

使用此示例对象: { “ISS”: “乔”,    “EXP”:1300819380,    “http://example.com/is_root”:真}

代码片段:

var eClaim = UTF8.encode(JSON.stringify(claim));
eClaim = Base64EncodeUrl(eClaim);

我的Base64url是:

eyJpc3MiOiJqb2UiL----CJleHAiOjEzMDA4MTkzODAs----Imh0dHA6Ly9leGFtcGxlLmNvbS9pc19yb290Ijp0cnVlfQ

( - 由我添加)

规格说我应该得到什么:

eyJpc3MiOiJqb2UiLA0KICJleHAiOjEzMDA4MTkzODAsDQogImh0dHA6Ly9leGFtcGxlLmNvbS9pc19yb290Ijp0cnVlfQ

我的编码对象中存在间隙(我再次添加----以显示间隙)。我虽然它可能是\ n,\ r或\ t但是没有一个符合预期的结果。我将示例粘贴到在线base64url编码器/解码器中。我的base64完美解码,示例JSON编码与我的完全相同。我做错了什么或者网络草案不正确吗?

1 个答案:

答案 0 :(得分:2)

你说你试过\ r和\ n,但这就是我在解码之后所确定的 你的样品。

不同之处在于示例版本中的换行符CRLF

他们的:

0000000  7b  22  69  73  73  22  3a  22  6a  6f  65  22  2c  0d  0a  20
          {   "   i   s   s   "   :   "   j   o   e   "   ,  cr  nl  sp
0000020  22  65  78  70  22  3a  31  33  30  30  38  31  39  33  38  30
          "   e   x   p   "   :   1   3   0   0   8   1   9   3   8   0
0000040  2c  0d  0a  20  22  68  74  74  70  3a  2f  2f  65  78  61  6d
          ,  cr  nl  sp   "   h   t   t   p   :   /   /   e   x   a   m
0000060  70  6c  65  2e  63  6f  6d  2f  69  73  5f  72  6f  6f  74  22
          p   l   e   .   c   o   m   /   i   s   _   r   o   o   t   "
0000100  3a  74  72  75  65  7d
          :   t   r   u   e   }
0000106

你的:

0000000  7b  22  69  73  73  22  3a  22  6a  6f  65  22  2c  22  65  78
          {   "   i   s   s   "   :   "   j   o   e   "   ,   "   e   x
0000020  70  22  3a  31  33  30  30  38  31  39  33  38  30  2c  22  68
          p   "   :   1   3   0   0   8   1   9   3   8   0   ,   "   h
0000040  74  74  70  3a  2f  2f  65  78  61  6d  70  6c  65  2e  63  6f
          t   t   p   :   /   /   e   x   a   m   p   l   e   .   c   o
0000060  6d  2f  69  73  5f  72  6f  6f  74  22  3a  74  72  75  65  7d
          m   /   i   s   _   r   o   o   t   "   :   t   r   u   e   }
0000100

据我所知,JSON在分隔符逗号后不需要换行符。