我正在尝试使用the node-jose library来解密JWE,但是在使用密钥的base64时遇到了问题(按照外部API的指示)。
const crypto = require('crypto');
const jose = require('node-jose');
const secret = 'mySecret';
let hash = crypto.createHash('sha512');
let data = hash.update(secret, 'utf-8');
let token = getToken(); // Token is a correctly formatted JWE
const key = JSON.stringify({ key: data.digest('base64'), kty: 'oct', alg: 'HS512', use: 'enc' });
jose.JWK.asKey(key).
then(function (result) {
jose.JWE.createDecrypt(result.keystore).
decrypt(token).
then(function (result) {
console.log(result);
}).catch(err => {
console.log(err);
});
});这将返回以下错误:
Error: no key found
我是不是在密钥的初始化过程中做错了什么?任何帮助都将不胜感激。
发布于 2018-10-29 22:56:10
通过以下几点,我成功地让它工作起来:
const crypto = require('crypto');
const jwt = require('jsonwebtoken');
const jose = require('node-jose');
const secret = 'mySecret';
let token = getToken(); // Token is a correctly formatted JWE
let keystore = jose.JWK.createKeyStore();
// *****The crucial bit*****
const bufferderived = crypto.createHash('sha512')
.update(secret)
.digest()
.slice(0, 512 / 8);
keystore.add({
k: bufferderived,
kty: 'oct',
alg: 'dir'
})
.then(function (result) {
console.log(result);
jose.JWE.createDecrypt(keystore).
decrypt(token).
then(function (result) {
const decryptedToken = result.plaintext.toString('utf8');
const decoded = jwt.decode(decryptedToken);
}).catch(err => {
console.log(err);
})
});https://stackoverflow.com/questions/53043425
复制相似问题