在 Nodejs 上使用来自 GoDaddy 的私钥

Using private key from GoDaddy on Nodejs

我们在godaddy上购买了域名和SSL证书,但是我们的服务器不在godaddy上。我们在我们的服务器中 运行 Lampp 和 NodeJS,我们正在尝试为两者设置 SSL。兰普没有问题。来自 Godaddy 的私钥和证书正在运行。但是当我用 NodeJS 尝试相同的文件时。它失败了。

这是我的 js 脚本:

ssl = {
key: fs.readFileSync("./key.pem",'utf8'),
cert: fs.readFileSync("./cert.crt",'utf8'),
ca: [fs.readFileSync('./g1.crt','utf8'), 
fs.readFileSync('./g2.crt','utf8'), fs.readFileSync('./g3.crt','utf8')]
};
server = require('https').createServer(ssl, app);

这是错误

_tls_common.js:104
  c.context.setKey(options.key, options.passphrase);
            ^

  Error: error:0909006C:PEM routines:get_name:no start line

谷歌搜索后,我尝试了几种解决方案:添加 "utf8"、拆分 gd 包、使用 nodepad++ 修复代码。 None 其中有帮助。

但是,nodejs 可以使用我的自签名密钥和证书文件。所以我想问一下。我是否错误地生成了我的密钥?我应该在本地手动生成 private key/CSR 并在 GoDaddy 上申请新证书吗?还是我的代码有问题?

此错误消息意味着这些文件是错误的、损坏的或者是为其他 OS Enviroments 请求的。所以我们有一些选择。

  1. 关于代码的解决方案(导入文件系统库并使用完整路径)。
let yourKey = fs.readFileSync('./folderOne/folderTwo/initial.key').toString();
let yourCertificate = fs.readFileSync('./folderOne/folderTwo/certificate.crt').toString();
var credentials = { key: yourKey, cert: yourCertificate };
  1. 根据 OS 兼容性要求的解决方案:
    • 请求新证书,并附上关于 OS(Linux、Windows 等)发送给您的提供商的初始密钥的注释。

重要提示:您只需要 .crt 文件和私钥。