首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用节点-jose,我如何解密我刚刚加密的数据?

使用节点-jose,我如何解密我刚刚加密的数据?
EN

Stack Overflow用户
提问于 2017-08-03 04:56:33
回答 1查看 5.9K关注 0票数 8

我正在尝试使用JOSE实现简单的encryptdecrypt函数。

我的代码如下(使用Node 8.2.1编写)

代码语言:javascript
复制
const { JWE } = require('node-jose');

const jose = (publicKey, privateKey) => {
  async function encrypt(raw) {
    if (!raw) throw new Error('Missing raw data.')
    const buffer = new Buffer(JSON.stringify(raw));
    return JWE.createEncrypt(publicKey).update(buffer).final();
  }

  async function decrypt(encrypted) {
    if (!encrypted) throw new Error('Missing encrypted data.')
    const buffer = new Buffer(JSON.stringify(encrypted));
    return JWE.createDecrypt(privateKey).decrypt(buffer);
  }

  return { encrypt, decrypt }
}

module.exports = jose;

我使用generate-rsa-keypair生成一个RSA密钥区。

因此,通过这段代码进行测试,加密端的功能很好。

代码语言:javascript
复制
const { JWK } = require('node-jose');
const keygen = require('generate-rsa-keypair');
const jose = require('./src/utils/jose');

const rawKeys = keygen();

const makeKey = pem => JWK.asKey(pem, 'pem');

async function start() {
  const publicKey = await makeKey(rawKeys.public)
  const privateKey = await makeKey(rawKeys.private)

  const raw = {
    iss: 'test',
    exp: new Date().getTime() + 3600,
    sub: {
      test: 'This is a test',
    },
  };

  const { encrypt, decrypt } = jose(publicKey, privateKey);

  return encrypt(raw).then(encrypted => decrypt(encrypted));
}

return start().then((result) => {
  console.log('decrypted', result)
}, (err) => {
  console.error(err);
});

encrypted的结果是

代码语言:javascript
复制
{
  recipients: [ { encrypted_key: 'ciNiK6Unq30zCAXxIl2Dx9b8bZAi79qbpL1yUCwTFnSghFLrIZ11_D2ozt5on3r3ThUu96oDLZPcNShbqWPMV49NvQAsSNGdemhgzmTt3Lf3rJn1YiqvJvqf5NIXdmzjdoEZi-d9224mGpZGVKtIIFeT6-0hYgm5zNqq_aF_X2jy5IiF-mAGspNdXIk_KXPrTVbnU-XL9J5aAoG2Lp51Te1WzGA4Fjg4Ve5ZTzH6TLlQ5R5Ob_14liK-INrSi3armwXrtMgJcTmI_4oBtORtZp8AjaXzecFO_GzifvRVCSKx2vmpy9KaECpskMhZBHVx9RX9cvGKh7hq3Y7vsUucZw' } ],
  protected: 'eyJhbGciOiJSU0EtT0FFUCIsImtpZCI6IldLWS1ONDRXM2RnanA4U2ZxSlp3TldqV3AzUG1XZ29UczhjRDh3eWNSUWciLCJlbmMiOiJBMTI4Q0JDLUhTMjU2In0',
  iv: 'wvqir2ewtQPfDHQtzl6IUg',
  ciphertext: 'ZwIrL_3739LI17rh3gWDUA6lXIL7ewkSh54FO_RwumC0qh9B0DcAr8RyXsfPbW19cV4u7SbZNSRP6B8qNOTy-2iENlqBISfE_kolDt8g5sg',
  tag: 'z8nwrJfRgOi1hYMBI9lGeQ'
}

但当我试图解密的时候

代码语言:javascript
复制
Error: no key found
  at processKey (node_modules/node-jose/lib/jwe/decrypt.js:157:22)

很少有使用node-jose的例子,所以我不确定以下几点

  1. 我想我应该用私钥解密。但这只是一个假设。没有一个示例显示使用了公钥/私钥对,只有一个密钥。
  2. 我假设加密的结果可以被压缩并转换为一个缓冲区,然后传递到decrypt中,但情况可能并非如此。

这到底是怎么回事?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-08-07 18:10:57

  1. 当使用公钥/私钥对时,private密钥用于解密,public密钥用于加密。
  2. JWEDecrypter.decrypt()的输入是JWEEncrypter.final()承诺的输出。

decrypt函数更改为:

代码语言:javascript
复制
async function decrypt(encrypted) {
  if (!encrypted) throw new Error('Missing encrypted data.')
  return JWE.createDecrypt(privateKey).decrypt(encrypted);
}
票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/45475145

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档