我们在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++ 修复代码。他们都没有帮助。
但是,nodejs 可以使用我的自签名 key 和证书文件。所以我想问一下。我是否错误地生成了我的 key ?我应该在本地手动生成私钥/CSR 并在 GoDaddy 上申请新证书吗?还是我的代码有问题?
最佳答案
此错误消息意味着这些文件是错误的、损坏的或被请求用于其他 OS Enviroments .所以我们有一些选择。
- 关于代码的解决方案(导入文件系统库并使用完整路径)。
let yourKey = fs.readFileSync('./folderOne/folderTwo/initial.key').toString();
let yourCertificate = fs.readFileSync('./folderOne/folderTwo/certificate.crt').toString();
var credentials = { key: yourKey, cert: yourCertificate };
- 请求每个操作系统兼容性的解决方案:
- 请求新证书,并附上有关操作系统(Linux、Windows 等)的注释,该操作系统会发送发送给您的提供商的初始 key 。
重要提示:您只需要 .crt 文件和私钥。
关于javascript - 在 Nodejs 上使用来自 GoDaddy 的私钥,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55500193/