2017-04-03 313 views
1

我有一个Node.js服务器,域上有一个活动的SSL证书。 我已经阅读了一些关于这个网站的回复,但即使当我涉及这些已经解决的问题时,我也会得到一个错误。使用Node.js将http重定向到https

var express = require('express'); 
var https = require('https'); 
var http = require('http'); 
var path = require('path'); 
var fs = require('fs'); 
var mysql = require('mysql'); 

var queue = {}; 
var qc = {}; 

var app = express(); 

var options = { 
    key: fs.readFileSync('sslcert/domain-name.key', 'utf8'), 
    cert: fs.readFileSync('sslcert/domain-name.csr', 'utf8') 
}; 

var httpServer = http.createServer(app); 
var httpsServer = https.createServer(options, app); 

/* various stuff to display my website */ 

httpServer.listen(process.env.PORT); 
httpsServer.listen(process.env.PORT); 

我在我的控制台中出现以下错误。

_tls_common.js:67 
     c.context.setCert(options.cert); 
       ^

Error: error:0906D06C:PEM routines:PEM_read_bio:no start line 
    at Error (native) 
    at Object.createSecureContext (_tls_common.js:67:17) 
    at Server (_tls_wrap.js:754:25) 
    at new Server (https.js:17:14) 
    at Object.exports.createServer (https.js:37:10) 
    at Object.<anonymous> (/srv/data/web/vhosts/default/server.js:35:25) 
    at Module._compile (module.js:409:26) 
    at Object.Module._extensions..js (module.js:416:10) 
    at Module.load (module.js:343:32) 
    at Function.Module._load (module.js:300:12) 

预先感谢您的回答!

Noël。

+0

[OpenSSL:PEM例程:PEM \ _read \ _bio:no start line:pem \ _lib.c:703:Expectcting:TRUSTED CERTIFICATE](http://stackoverflow.com/questions/20837161/openssl- PEM-routinespem - 读biono-启动linepem-LIB-c703expecting,TRUSTe的) –

回答

1

cert应该是您的域的PEM格式化证书,后面是PEM格式的中间证书;而不是CSR。

cert: fs.readFileSync('sslcert/domain-name.pem', 'utf8')

1

除了阿南德铢注意,就像你正在试图做的,你不应该这两个服务器绑定到同一端口的答案:

httpServer.listen(process.env.PORT); 
httpsServer.listen(process.env.PORT); 

也许工作但它可能不符合你的期望。如果你这样做:

httpServer.listen(process.env.PORT_HTTP); 
httpsServer.listen(process.env.PORT_HTTPS); 

其中PORT_HTTP是如80和PORT_HTTPS是例如443,你总是会知道哪个服务器会处理哪个请求。