NODE应用程序的SSL设置

时间:2018-10-31 09:29:21

标签: express cors mean

我的节点应用程序端口已在https://www.example.com:3001上成功运行,但是在提交详细信息时出现了CORS问题

跨域请求被阻止:“同源起源”策略禁止读取https://www.example.com:3001/user/findUser上的远程资源

注意:如果没有使用https,则该应用程序可以正常运行,但是SSL(https)出现了问题...非常感谢您提供任何帮助

我的代码

//app.js used for configuring the application

const express = require('express'); //getting express module
const db = require('./database/database-db'); //Database connection file
const UserController = require('./user/UserController');
const DataController = require('./user/DataController');
const app = express();

const cors = require('cors');

app.use(function (req, res, next) {
	// res.setHeader('Access-Control-Allow-Origin', 'http://localhost:4200'); 
    res.setHeader('Access-Control-Allow-Origin', 'https://www.example.com'); 
	res.setHeader('Access-Control-Allow-Methods', 'POST');
	res.setHeader('Access-Control-Allow-Headers', 'X-Requested-With,content-type');
	res.setHeader('Access-Control-Allow-Credentials', true);
	next();
  });


//importing UserController and it appears /user/allOtherURIs
app.use(cors());
app.use('/user', UserController);
app.use('/data', DataController);
app.get('/', function(req, res){
res.send('Welcome to MY-API');
});




//this should be exported because to make available all the imported modules in this file

module.exports = app;

'use strict' ;

 
//server.js for spinning up the node server on a specific port 3001

//  var app = require('./app/app.js');           //making all the modules in app.js available


//  var port = process.env.PORT || 3001 ; //setting port 
//  var server = app.listen(port, function(){
//   console.log("Server is running on http://localhost:%s", port);
//   });

//ssl port settings

var https = require('https');
var fs = require('fs');

var options = {
  key: fs.readFileSync('key.key'),
  cert: fs.readFileSync('cert.crt'),
};

https.createServer(options, function (req, res) {
  res.writeHead(200);
  res.end("Welcome");
}).listen(3001);

   

app.js代码是:

1 个答案:

答案 0 :(得分:0)

最后这是代码

var express = require('express');
var DataController = require('./user/DataController');
var UserController = require('./user/UserController');
var db = require('./database/database-db'); 
var cors = require('cors');
var app = express();
app.use(cors());

app.use(function(req, res, next) {
res.setHeader("Access-Control-Allow-Origin", "https://www.example.com");
res.setHeader("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept");
res.setHeader('Access-Control-Allow-Methods', 'POST');
res.setHeader('Access-Control-Allow-Credentials', true);
next();
});

app.use('/user', UserController);
app.use('/data', DataController);
app.get('/', function(req, res){
res.send("Welcome");
});

// This settings are for HTTPS, SSL web applications

var https = require("https");
var fs = require("fs");

var options = {
  key: fs.readFileSync("key.key"),
  cert: fs.readFileSync("cert.crt")
 };
https.createServer(options,app).listen(3001);
console.log('Welcome')



// // This settings are only for HTTP sites

// var http = require("http");
// var fs = require("fs");

// http.createServer(app).listen(3001);
// console.log('Welcome')