完全复杂的json对象$ http.post到node.js失败

时间:2019-06-17 23:38:02

标签: node.js angularjs parsing

我有这个angularJs更新查询:

$http.post('http://localhost:3000/updateClub?club='+club)

Node.JS可以看到某些内容但无法更新,这是节点jsconsole:

Example app listening on port 3000!
(node:3756) DeprecationWarning: current URL string parser is deprecated, and will be removed in a future version. To use the new parser, pass option { useNewUrlParser: true } to MongoClient.connect.
express deprecated req.param(name): Use req.params, req.body, or req.query instead app.js:118:20
{ club: '[object Object]' }
undefined

这是我的node.js代码:

 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");
  next();
});

    const bodyParser = require('body-parser')

    // create application/json parser
    const jsonParser = bodyParser.json()



    app.post('/updateClub', jsonParser, function (req, res) {

            console.log(req.query);
            console.log(req.query.categorie); //Fails

            var myClub = req.query;

            MongoClient.connect('mongodb://localhost:27017', (err, client) => {
                var db = client.db('myDb');
                db.collection('clubs').updateOne({"_id":myClub._id},{$set:myClub}); 
            });

        })

这是我的俱乐部对象,请注意,其中包含一个数组以及一个对象(还有一个> prototype <部分,我不知道如何删除它):

Object { _id: "5d07e982a7d75a67d6383d6b", nom: "Angers Sp", identifiant: 4, date_creation: Date 1919-01-01T00:00:00.000Z, categorie: "professionel", structure: "Ligue 1", affectations: [], img: "…", adresse: {…}, ville: "Angers", … }

我也在firefox中收到此错误消息,但是当参数为node.js时,它仍然会获取数据:

Cross-Origin Request Blocked: The Same Origin Policy disallows reading the remote resource at http://localhost:3000/updateClub?club=[object%20Object]. (Reason: CORS request did not succeed).

如果有人可以帮助我,我将非常感谢。 其他的node.js查询仅使用参数,而不使用完整的对象。

我的俱乐部收藏很好,并且已经包含25个俱乐部

编辑1: 将我的http查询更改为:

$http.post('http://localhost:3000/updateClub',{data:$.param(club)})

现在,node.js req.body似乎获取了对象(文档):

{ data:
   '_id=5d07e982a7d75a67d6383d6b&nom=Angers+Sporting+Club+de+l\'Ouest+(SCO+Angers)&identifiant=4&date_creation=Wed+Jan+01+1919+00%3A00%3A00+GMT%2B0000+(Central+European+Standard+Time)&categorie=professionel&structure=Ligue+1&img=data%3Aimage%2Fpng%3Bbase64%2CiVBORw0KGgoAAAANSUhEUgAAAYAAAAILCAYAAADhWEs5AAAABmJLR0QA%2FwD%2FAP%2BgvaeTAAAgAElEQVR4nOydd3hURffHv2mb3nsICQkhNNEAoQVBBfnRpFhAioIgwouAovQirwoiSEelKaBIF0SkCUhRREpCkRICoaU3kuym9%2Fn9sWTfBLbembt3s5nP88yT7O6dmXPn7s6ZOXPmDMDhcDgcDofD4XA4HA6Hw%2BFwOBwOh8PhcDgcs8FCagE49RoXAE4AnB%2F%2Fda%2Fxv%2FPjZAfA3oC%2FT5ZvVeO1BQA3HTKVASjU8FkBgPLH%2F8sBEACVAPIev1cCoLhGGfmP38t%2FnLfk8bWFj%2F9XPP5f%2FjiV6JCNw2EKVwAcWuwAeALwqPHXA4DXE%2B9V%2F3WFsoPX1RHXR4rxP2UgB5Cr5nUWgEePU%2Frj10VSCMup%2B3AFwFGHDIAPAH8Avo%2F%2FD3j81xeAX43PXSWSkfM%2FivA%2FhfAI%2F1MSKY%2FfSwKQ%2BjjxWQZHBVcA9Q8ZlB13QwBBAAIfpyAADR7%2F7

不再有cors警告

现在这是我最后的node.js代码:

app.post('/updateClub', jsonParser, function (req, res) {

    console.log(req.body); // Can see the object in the console !

    var myClub = req.body;
    MongoClient.connect('mongodb://localhost:27017', (err, client) => {
        var db = client.db('myDb');
        db.collection('clubs').updateOne({"_id":myClub._id},{$set:myClub}); // Fails
    });

})

它仍然不会更新mongodb上的对象

编辑2:

谢谢乔治,将我的前端查询更改为:

  $http.post('http://localhost:3000/updateClub',club)

现在,这是节点控制台显示的内容,它是一个结构良好的对象(对不起,无法显示全部内容,还有烦人的base64图片):

{ _id: '5d07e982a7d75a67d6383d6b',
  nom: 'Angers Sporting Club',
  identifiant: 4,
  date_creation: '1919-01-01T00:00:00.000Z',
  categorie: 'professionel',
  structure: 'Ligue 1',
  affectations: [],
  img: ...

这是我最新的node.js代码:

app.post('/updateClub', jsonParser, function (req, res) {

    console.log(req.body); // Can see the well formed object in the console !

    var myClub = req.body;
    MongoClient.connect('mongodb://localhost:27017', (err, client) => {
        var db = client.db('myDb');
        db.collection('clubs').updateOne({"_id":myClub._id},{$set:myClub}); // There must be a mispelling, i need to replace the whole object (document)
    });

})

编辑3:尝试使用replaceOne()

app.post('/updateClub', jsonParser, function (req, res) {

    console.log(req.body); // Can see the object in the console !

    var myClub = req.body;
    MongoClient.connect('mongodb://localhost:27017', (err, client) => {
      if (err) throw err;       
     var db = client.db('myDb');
        db.collection('clubs').replaceOne({"_id":myClub._id},myClub); // Fails silently
    });

    })

注意:尝试了很多事情,insert()可以工作,但是replaceOne()不能!

编辑4

将我的node.js替换为:

try {
    db.collection('clubs').replaceOne({_id:"5d07e982a7d75a67d6383d6b"},myClub)
} catch (e){
   print(e);
}

这仍然没有更新!可能是因为“ myClub”文档太大了吗? console.log(myClub._id)正在运行,但是replaceOne()静默失败!

console.log(typeof(myClub))提供对象,所以应该没问题!

编辑6: ANGULARJS对象与node.js收到的对象不同!

我发现了错误,Node.js解析的JSON包含[Object]而不是嵌套的对象数据:

adresse:
   { address_components:
      [ [Object],
        [Object],
        [Object],
        [Object],
        [Object],
        [Object],
        [Object] ],
     adr_address:

如何摆脱这种情况并获取真实对象数据? (AngularJs发送的对象包含所有“对象”数据,然后node.js用[object]替换它,为什么,请帮忙?

编辑7: 将我的前端更改为:

 $http.post('http://localhost:3000/updateClub',club, {headers: {'Content-Type': 'application/json'} })

将我的node.js代码更改为此:

const jsonParser = bodyParser.json()
app.use(bodyParser.json({
    inflate: true,
    strict:false
}));

我的嵌套JSON对象仍然没有解析,相反,有[object]

我已经尝试了所有选项:https://github.com/expressjs/body-parser?_ga=1.163627447.940445150.1418712389#bodyparserurlencodedoptions

我应该怎么做才能获取嵌套对象的内容?

编辑8

我从官员那里得到了答案:

默认情况下,Node.js console.log仅显示深度为2:

如此

console.dir(req.body,{depth:Infinity})正确显示了整个JSON文档。

所以我真的不知道为什么replaceOne()不起作用,我发白了,我没有解释。

编辑9:已解决

我最终得到了这段代码,但是我不认为这是最好的做法,我添加了第二个标识符,该标识符来自我的旧bdd,因此我将其用作过滤器,并删除了mongoDb生成的_id,该标识符是生成错误,则替换工作正常:

  app.post('/updateClub', function (req, res) {


        myClub = req.body;

        delete myClub._id;

        MongoClient.connect('mongodb://localhost:27017', { useNewUrlParser: true }, (err, client) => {


            if (err) throw err;
            var db = client.db('myDb');

            try {
            db.collection('clubs').replaceOne({"identifiant":myClub.identifiant},myClub)
            } catch (e){
               print(e);
            }
        })
    })

编辑:尝试从myClub._id中删除引号,并尝试提供的第一个没有运气的代码 myClub._id = myClub._id.replace(/ [“'] / g,”“);

这是myClub._id:5d07e982a7d75a67d6383d6c,看起来不错

最终:

好的,我在那里找到了一个解释:

https://litote.org/kmongo/dokka/kmongo/org.litote.kmongo/com.mongodb.client.-mongo-collection/replace-one-with-filter.html

好吧,我需要使用_id才能替换一个,这更方便。

0 个答案:

没有答案