2017-08-10 92 views
1

我想我的角度应用程序连接到我的节点服务器,我不想让我的路线在服务器上的文件,所以我有一个节点服务器文件看起来像这样CORS问题节点JS

var express   = require('express'); 
    var path   = require('path'); 
    var bodyParser  = require('body-parser'); 
    var morgan   = require('morgan'); 
    var app    = express(); 
    var router   = express.Router(); 
    var port   = process.env.PORT || 3000; 
    var mongoose  = require('mongoose'); 
    var cors   = require('cors'); 

    app.use(cors()) 
    var db ='mongodb://localhost:27017/demo' 
    mongoose.connect(db,function(err){ 
     if(err){ 
     console.log("err"); 
     } 
     else{ 
     console.log("coonected to db"); 
     } 
    }) 


    app.use(bodyParser.urlencoded({ extended: false })); 
    app.use(bodyParser.json()); 
    app.use(morgan('dev')); 


    app.set('views', path.join(__dirname,'views')); 
    app.set('view engine','ejs'); 
    app.engine('html',require('ejs').renderFile); 

    app.use(express.static(path.join(__dirname,'app'))); 
    app.use(bodyParser.json()); 
    app.use(bodyParser.urlencoded({extended:false})); 

    app.get('/',function(req,res){ 
     console.log("you have reached server"); 
     res.json('wtf'); 
    }) 


    module.exports = app; 
    require('./route.js'); 
    app.listen(port); 

在route.js我有这样我的路线

var login = require ('./api/login'); 
    var app  = require('./server') 
    app.get('/login',login.authenticate); 

它工作正常,如果我使用节点服务器上,但如果我用它的角服务器上就说明这个错误:

从重定向“本地主机:3000 /登录'到'localhost:3000/login /'已被CORS策略阻止:在请求的资源上没有'Access-Control-Allow-Origin'标头。因此不允许访问Origin'localhost:4200'。

It only happens to the routes that I define in `route.js`. If I define the same route in `server.js` they work fine. 

PS: I have also used 
app.use(function(req, res, next) { 
    res.header("Access-Control-Allow-Origin", '*'); 
    res.header("Access-Control-Allow-Credentials", true); 
    res.header('Access-Control-Allow-Methods', 'GET,PUT,POST,DELETE,OPTIONS'); 
    res.header("Access-Control-Allow-Headers", 'Origin,X-Requested-With,Content-Type,Accept,content-type,application/json'); 
    next(); 
}); and some variation of this code but nothing works if I want to route to login url which is in my route file 
+0

为什么你在routes.js里面配置你的应用程序? – echonax

+0

我是新来的节点,我想保持路线在一个单独的模块 –

+0

这很好,但这是你的快速设置的配置,可以保持你的server.js中的表达相关的配置是好的。但是,如果您可以在routes.js中添加用法,也许我们可以找到解决方案。 – echonax

回答

1

您的应用程序在routes.js和server.js中不引用相同的内容。因此你的“app”在routes.js中不起作用。

:如果你想使用的应用程序=快车()在routes.js你可以这样才能实例化这样的路线您routes.js应该像添加像这里面server.js

var Routes = require('./routes.js'); 
var r = new Routes(app); 

module.exports = function(app){ 
    var login = require ('./api/login'); 
    app.get('/login',login.authenticate); 
    ... 
} 

老答案:

由于@Anurag Singh Bisht还回答了你应该允许跨域请求。我的答案是略有不同:

app.use(function(req, res, next) { 
    res.header("Access-Control-Allow-Origin", '*'); 
    res.header("Access-Control-Allow-Credentials", true); 
    res.header('Access-Control-Allow-Methods', 'GET,PUT,POST,DELETE,OPTIONS'); 
    res.header("Access-Control-Allow-Headers", 'Origin,X-Requested-With,Content-Type,Accept,content-type,application/json'); 
    next(); 
}); 
+0

感谢您的回答,但很抱歉,此解决方案无法正常工作。 –

0

您需要在您的服务器中使用allow cross origin,以便您的前端可以访问它。

app.use(function(req, res, next) { 
    res.header("Access-Control-Allow-Origin", "*"); 
    res.header("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept, Authorization"); 
    next(); 
}); 
+0

我已经使用这个,但它显示相同的错误,但感谢您的帮助 –

0

你需要下面的代码添加用于处理preflight请求从浏览器发送。

const cors = require('cors') 
const corsOptions = { 
    origin: '*' 
} 
app.use(cors(corsOptions)) 

app.use(function(req, res, next) { 
    res.header("Access-Control-Allow-Origin", '*'); 
    res.header("Access-Control-Allow-Credentials", true); 
    res.header('Access-Control-Allow-Methods', 'GET,PUT,POST,DELETE,OPTIONS'); 
    res.header("Access-Control-Allow-Headers", 'Origin,X-Requested-With,Content-Type,Accept,content-type,application/json'); 
    next(); 
});