自定义iojs插件无法加载RSA私钥

时间:2015-03-04 03:00:32

标签: c++ node.js openssl io.js

我尝试在iojs插件中加载RSA私钥的代码段。

void IojsAddon::New(const FunctionCallbackInfo<Value>& args) {
  Isolate* isolate = Isolate::GetCurrent();
  HandleScope scope(isolate);

  if (args.IsConstructCall()) {
    EVP_PKEY* ca_key;
    BIO* keyb = BIO_new(BIO_s_file());
    BIO_read_filename(keyb, "/path/to/key.pem");
    ca_key = PEM_read_bio_PrivateKey(keyb, nullptr, nullptr, nullptr);

    std::cout << "type: " << ca_key->type << std::endl; // type: 6
    std::cout << "check: " << RSA_check_key(ca_key->pkey.rsa) << std::endl; // check: -1
    RSA_print_fp(stdout, ca_key->pkey.rsa, 0);  // Segmentation fault: 11

    IojsAddon* addon = new IojsAddon();
    addon->Wrap(args.This());
    args.GetReturnValue().Set(args.This());
  } else {
    const int argc = 1;
    Local<Value> argv[argc] = { args[0] };
    Local<Function> cons = Local<Function>::New(isolate, constructor);
    args.GetReturnValue().Set(cons->NewInstance(argc, argv));
  }
}

在独立应用程序中成功加载RSA私钥的代码段,与前一个完全相同。

int main(int argc, char **argv) {
  EVP_PKEY* ca_key;
  BIO* keyb = BIO_new(BIO_s_file());
  BIO_read_filename(keyb, "/path/to/key.pem");
  ca_key = PEM_read_bio_PrivateKey(keyb, nullptr, nullptr, nullptr);

  std::cout << "type: " << ca_key->type << std::endl;  // type: 6
  std::cout << "check: " << RSA_check_key(ca_key->pkey.rsa) << std::endl; // check: -1 
  RSA_print_fp(stdout, ca_key->pkey.rsa, 0);  // print out the key info successfully.
  return (0);
}

P.S。

  • iojs:v1.2.0
  • pangyp:v2.0.1

我在这里想念什么?任何帮助都会很感激!

1 个答案:

答案 0 :(得分:0)

我会在这里回答我自己的问题。通过在binding.gyp中包含openssl头文件来解决它。我已经成功读取了X509证书而没有包含任何头文件,我只是假设构建系统会为我做这件事。但事实并非如此。你必须自己做。

查看Linking-to-OpenSSl了解有关使用openssl处理iojs插件的更多信息。