Я сгенерировал фиктивный SSL-сертификат, используя OpenSSL, и импортировал его на сервер nodejs.и запустил сервер с https.Внешний интерфейс - это приложение angular 6 (config HTTPS с Let's-encrypt && nginx), но оно работает на другом экземпляре aws, а сервер узла находится на другом экземпляре.Я также обработал CORS, но всякий раз, когда звонок с https angular на внутренний HTTPS-сервер ничего не отвечает.но когда я пытаюсь с HTTP все работает нормально.
.`
var originsWhitelist = [
'http://XXX.XX.XX.XXX.:8080',
'https://test.XXXXX.in/'
];
var corsOptions = {
origin: function(origin, callback){
var isWhitelisted = originsWhitelist.indexOf(origin) !== -1;
callback(null, isWhitelisted);
},
credentials:true
}
app.use(cors(corsOptions));
app.use((req,res,next) => {
res.header("Access-Control-Allow-Origin", "*");
res.header("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept");
if (req.method === 'OPTIONS') {
res.header('Access-Control-Allow-Methods', 'PUT, POST, PATCH, DELETE, GET');
return res.status(200).json({});
}
const error = new Error('Not found');
error.status = 200;
next(error);
});
var options = {
key: fs.readFileSync(path.join(__dirname,'privateKey','client-key.pem')),
cert: fs.readFileSync(path.join(__dirname,'privateKey','client-cert.pem'))
};
http.createServer(app).listen(3000 , ()=>{
console.log('Started up HTTP at port 3000');
});
https.createServer(options, app ).listen(3001, ()=>{
console.log('Started up HTTPS at port 3001');
});