Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/extjs/3.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
离子型3+;和节点/Express:的Http失败响应(未知url):0_Express_Mongoose_Cors - Fatal编程技术网

离子型3+;和节点/Express:的Http失败响应(未知url):0

离子型3+;和节点/Express:的Http失败响应(未知url):0,express,mongoose,cors,Express,Mongoose,Cors,我一直试图从本地mongodb数据库获取数据,但没有成功 我已经使用express、cors和mongoose设置了一个节点服务器 根据我在互联网上看到的情况,这应该是可行的: var express = require('express'); var app = express(); var mongoose = require('mongoose'); var cors = require('cors'); app.use(cors({credentials: true, origin: "

我一直试图从本地mongodb数据库获取数据,但没有成功

我已经使用express、cors和mongoose设置了一个节点服务器

根据我在互联网上看到的情况,这应该是可行的:

var express = require('express');
var app = express();
var mongoose = require('mongoose');
var cors = require('cors');
app.use(cors({credentials: true, origin: "*", methods: "GET,HEAD,PUT,PATCH,POST,DELETE", preflightContinue:true}));

mongoose.connect('mongodb://localhost/cats');

const Cat = mongoose.model('Cat',{name:String, color:String});

const kitty = new Cat({name:'Alfred',color:'Black/White'});

// kitty.save().then(()=>{
//     console.log('meow');
// });



app.get('/cats', cors(), function(req, res) { 
    Cat.find({}, function(err, cats){
        if(err){
            res.send(err);
        } else {
            res.send(cats);
        }
    });
});

app.listen(8080,()=>{
    console.log('Listening on 8080');
});
我已经尝试了
app.use(cors())并使用此选项:

var allowCrossDomain = function(req, res, next) {
    res.header('Access-Control-Allow-Origin', '*');
    res.header('Access-Control-Allow-Methods', 'GET,PUT,POST,DELETE,OPTIONS');
    res.header('Access-Control-Allow-Headers', 'Content-Type, Authorization, Content-Length, X-Requested-With, Accept');

    // intercept OPTIONS method
    if ('OPTIONS' == req.method) {
        res.send(200);
    } else {
        next();
    }
};
app.use(allowCrossDomain);
但似乎什么都不管用

好吧,找出原因

我在手机上使用了
ionic-serve
命令进行测试,同时仍在提供商中保留了
localhost
地址。我必须托管节点服务器和mongo数据库才能正常工作(尽管我仍然必须使用本地节点服务器从我的计算机上的浏览器实验室访问它)

还更改了cors选项,现在看起来像:

app.all('*', function(res,req,next){
    res.header('Access-Control-Allow-Origin','*');
    res.header('Access-Control-Allow-Credentials',true);
    res.header('Access-Control-Allow-Methods','PUT, GET, POST, DELETE, OPTIONS');
    res.header('Access-Control-Allow-Headers','Content-Type');
    next();
});
在每个请求中也使用cors,如下所示:

app.get('/your/route/', cors(), function(req, res) { 
   // logic here
});

从客户端调用什么端点。你会犯什么错误?我只使用express,这对我有效-即使没有cors()