我发现了这种奇怪的行为,每次sha256签名对于相同的输入和键都是不同的。不知道为什么。这是代码和一些打印文件。
def apply(algorithm: String, data: String, key: String): Array[Byte] = {
val _key = Option(key).getOrElse(throw new IllegalArgumentException("Missing key for JWT encryption via " + algorithm))
val mac: Mac = Mac.getInstance(algorithm)
val secretKey: SecretKeySpec = new SecretKeySpec(_key.getBytes, algorithm)
mac.init(secretKey)
val res = mac.doFinal(data.getBytes)
println(s"$algorithm $data $key $res $secretKey")
res
}下面是测试套件中使用以下代码进行的日志记录:
HmacSHA256 eyJIZXkiOiJmb28ifQ== secretkey [B@4959742d javax.crypto.spec.SecretKeySpec@fa77d7a8
HmacSHA256 eyJIZXkiOiJmb28ifQ== secretkey [B@6a790e37 javax.crypto.spec.SecretKeySpec@fa77d7a8
HmacSHA256 eyJIZXkiOiJmb28ifQ== secretkey [B@2347f330 javax.crypto.spec.SecretKeySpec@fa77d7a8
HmacSHA256 eyJIZXkiOiJmb28ifQ== secretkey [B@5298db1f javax.crypto.spec.SecretKeySpec@fa77d7a8
HmacSHA256 eyJIZXkiOiJmb28ifQ== secretkey [B@5cb80eb0 javax.crypto.spec.SecretKeySpec@fa77d7a8为什么签名都不一样?
发布于 2014-04-17 12:34:54
您不是在查看签名,而是查看字节数组上的默认toString()方法调用。如果您检查实际字节,它们应该匹配。
https://stackoverflow.com/questions/23133130
复制相似问题