首页 > 解决方案 > 如何在节点中的函数调用中等待回调?

问题描述

好的,所以我正在尝试使用加密生成公钥和私钥(https://nodejs.org/api/crypto.html#crypto_crypto_generatekeypair_type_options_callback

问题是,generateKeyPair 的参数之一是回调函数,我无法让我的代码等待回调运行。它最终会运行,但到那时我已经尝试使用数据。这个想法是做这样的事情:

const _getKeyPair = (pwd: string): Object => {
    const { generateKeyPair }: any = require('crypto');

    const keyPair = { publicKey: '', privateKey: '' };
    generateKeyPair('rsa', {
        modulusLength: 4096,
        publicKeyEncoding: {
            type: 'spki',
            format: 'pem'
        },
        privateKeyEncoding: {
            type: 'pkcs8',
            format: 'pem',
            cipher: 'aes-256-cbc',
            passphrase: pwd
        }
    }, (err: Error, publicKey: string, privateKey: string) => {
        if (err) {
            throw err;
        }
        keyPair.publicKey = publicKey;
        keyPair.privateKey = privateKey;
    });

    return keyPair;
};

并调用:

const keyPair = _getKeyPair('myPassword');

标签: node.jstypescriptasync-await

解决方案


crypto有两种方法来生成密钥对,一种是异步的,另一种generateKeyPair是同步generateKeyPairSync的,如果你想要的话,你可以使用它们而不必担心回调。另一种方法是用 promise 包装方法并使用await. 就像是:

const _getKeyPair = async (pwd) => {
  const { generateKeyPair } = require('crypto');

  return new Promise((resolve, reject) => {
    generateKeyPair('rsa', {
      modulusLength: 4096,
      publicKeyEncoding: {
        type: 'spki',
        format: 'pem'
      },
      privateKeyEncoding: {
        type: 'pkcs8',
        format: 'pem',
        cipher: 'aes-256-cbc',
        passphrase: pwd
      }
    }, (err, publicKey, privateKey) => {
      if (err) return reject(err);
      resolve({publicKey, privateKey});
    });
  });
};

async function main() {
  const keyPair = await _getKeyPair('myPassword');
}

main();

推荐阅读