NodeJS、Angular、MongoDB、およびSailsフレームワークで構築された既存のカスタムアプリケーションを拡張しています。私はユーザーがサンドイッチを注文するためのフォームを作成しています。NodeJS、AngularJS、Mongo間違ったデータを返す文書の作成と更新
ユーザが選択すると、注文の詳細を格納するjavascriptオブジェクトが作成されます。そのオブジェクトは、データベースに既存の「カート」コレクションに追加する必要があります。
問題は、javascriptオブジェクトが「カート」コレクションに追加されたときに、非常に奇妙なドキュメントが作成されるということです。すべてのデータがそこにあるとは限りません。
次のコードは、カートを正常に更新する既存のコードに基づいています。既存のコードは私が継承したゴミ箱火災です。私はまだ学んでいるので、この問題のデバッグはかなり苦労しています。
は、ここでユーザーがフォームに記入する際に作成されたオブジェクトです。
//boxlunch object
{"boxlunchType":"Standard Traditional","sandwichesType":"sandwich","sandwichesTotalQty":8,"totalPrice":110,"sandwiches":[{"name":"Chicken Salad","qty":1},{"name":"Grilled Chicken Breast","qty":2},{"name":"Grilled Vegetables Provolone","qty":""},{"name":"Ham and Swiss Cheese","qty":""},{"name":"Roast Beef","qty":5}]}
オブジェクトは、単純な配列を作成し、この関数に渡されます。データは、データベース更新を実行するルートに渡されます。
/*Save boxlunch cart*/
$scope.saveCartBoxlunch = function(boxlunch) {
var boxlunchCart = [];
boxlunchCart.push(
{
'quantity' : boxlunch.sandwichesTotalQty,
'unitprice' : boxlunch.totalPrice,
'customer_id' : $rootScope.user.displayname,
'item_name' : boxlunch.boxlunchType
}
);
$sails.post('/boxlunchcart?boxlunch=' + boxlunchCart).then(function (data) {
});
};
ここでは、 "boxlunchcart"ルートによって呼び出される関数です。
boxlunchUpdateCart : function (req, res) {
var boxlunchCartJSON = req.param('boxlunch');
Cart
.find(
{
customer_id:req.session.user[0].displayname
}
)
.exec(function(err, cartchKObj) {
if (err) {
sails.log.error('Error finding cart data',err);
res.send(500, {title: 'Error finding cart data'});
//If cart does not exist create new
} else if (cartchKObj == '' || typeof cartchKObj == 'undefined') {
Cart
.create(boxlunchCartJSON)
.exec(function (err, cartObj){
sails.log.debug("Cart object: " + cartObj.id);
if(err){
res.send(500, {title: 'error Creating Boxlunch Cart'});
sails.log.error('Error Creating Boxlunch Cart',err);
} else {
sails.log.error('Cart Created Successfully',cartObj);
}
});
}
//If cart exists update existing
else {
sails.log.debug("cartchKObj " + cartchKObj[0].id);
Cart
.update({id : cartchKObj[0].id}, {quantity : 1})
.exec(function(err, cartUpdateObj) {
sails.log.debug("Cart update object: " + cartUpdateObj.id);
if (err) {
sails.log.error('Error Updating Boxlunch Cart',err);
res.send(500, {title: 'error Updating Boxlunch Cart'});
} else {
sails.log.debug('Boxlunch Cart Updated Successfully');
}
});
}
});
ここにすべてのsails.logメッセージの出力があります。
ご覧のとおり、この行は作成された新しいドキュメントObjectIDを出力します。
sails.log.debug("Cart object: " + cartObj.id);
//Output
{"level":"debug","message":"Cart object: 599b63483d6966050026189b","timestamp":"2017-08-21T22:48:40.728Z"}
この行は
sails.log.debug('Cart Created Successfully',cartObj);
//Output (added returns for readability)
{"level":"debug","message":"Cart Created Successfully
{ '0': '[',\n '1': 'o',\n '2': 'b',\n '3': 'j',\n '4': 'e',\n '5': 'c',\n '6': 't',\n '7': ' ',\n '8': 'O',\n '9': 'b',\n '10': 'j',\n '11': 'e',\n '12': 'c',\n '13': 't',\n '14': ']',\n bold: '\\u001b[1m[object Object]\\u001b[22m',\n
underline: '\\u001b[4m[object Object]\\u001b[24m',\n strikethrough: '\\u001b[9m[object Object]\\u001b[29m',\n italic: '\\u001b[3m[object Object]\\u001b[23m',\n inverse: '\\u001b[7m[object Object]\\u001b[27m',\n grey: '\\u001b[90m[object Object]\\u001b[39m',\n black: '\\u001b[30m[object Object]\\u001b[39m',\n yellow: '\\u001b[33m[object Object]\\u001b[39m',\n red: '\\u001b[31m[object Object]\\u001b[39m',\n green: '\\u001b[32m[object Object]\\u001b[39m',\n blue: '\\u001b[34m[object Object]\\u001b[39m',\n white: '\\u001b[37m[object Object]\\u001b[39m',\n cyan: '\\u001b[36m[object Object]\\u001b[39m',\n
magenta: '\\u001b[35m[object Object]\\u001b[39m',\n greyBG: '\\u001b[49;5;8m[object Object]\\u001b[49m',\n blackBG: '\\u001b[40m[object Object]\\u001b[49m',\n yellowBG: '\\u001b[43m[object Object]\\u001b[49m',\n redBG: '\\u001b[41m[object Object]\\u001b[49m',\n greenBG: '\\u001b[42m[object Object]\\u001b[49m',\n blueBG: '\\u001b[44m[object Object]\\u001b[49m',\n whiteBG: '\\u001b[47m[object Object]\\u001b[49m',\n cyanBG: '\\u001b[46m[object Object]\\u001b[49m',\n magentaBG: '\\u001b[45m[object Object]\\u001b[49m',\n
rainbow: '\\u001b[31m[\\u001b[39m\\u001b[33mo\\u001b[39m\\u001b[32mb\\u001b[39m\\u001b[34mj\\u001b[39m\\u001b[35me\\u001b[39m\\u001b[31mc\\u001b[39m\\u001b[33mt\\u001b[39m \\u001b[34mO\\u001b[39m\\u001b[35mb\\u001b[39m\\u001b[31mj\\u001b[39m\\u001b[33me\\u001b[39m\\u001b[32mc\\u001b[39m\\u001b[34mt\\u001b[39m\\u001b[35m]\\u001b[39m',\n zebra: '[\\u001b[7mo\\u001b[27mb\\u001b[7mj\\u001b[27me\\u001b[7mc\\u001b[27mt\\u001b[7m \\u001b[27mO\\u001b[7mb\\u001b[27mj\\u001b[7me\\u001b[27mc\\u001b[7mt\\u001b[27m]',\n stripColors: '[object Object]',\n
zalgo: '[̶̮̠̥͈̭̣͎̲̙͇̞̹̘͈̺͉̣̺͍̟͍̦̻̙͔͎̙̘̯̙̥̖̺̱̥̮̬̖̹͎̤̠̗̮̭̙̼̻̼̪̙͉͖̥̞̺̰̲͕͕̠͖̥̉̅̓̇̄ͥͅͅo̷͔̺͈̦̩͇̞̗̣͙̘̬̩̟̫̮̙̜̞̤̺̥͖̯̗̦̞͖̣̳̺̠̥̳̲̣̰̹͖̳̝͚̜̦̥̺͙̣̱̮͉̘̼͈̦̱̞͎͔̱̮̤̤̝͇̠ͦ̽̐͗͒̇̉ͩ͆̐b̞̮͓̭͔̭͈̗̪̤͓͎̰̟͙̤̳̦͇̯̖̣̺͉̠̹̱̪̱̮̙̝͖͇͈̲̘͚͙̻̬͍̩̥̭̲̫̬̲͚̱̟͙̂̒͊̐́̄ͪ̎̒ͥ͑̓͑͂ͯ͠ͅjͨ͋̈ͤ̅̊̚ ҉̰̝̣̮̘̘͉̗̣̥̮͚̭̹̠̥̖̰̟̠̹̜̙̜̻̠̥͍̩̟̳̞̩͉͙̪̖̥̣̩͍͍̜͉͈̣͉̗̝͙͚̘̰͕͉̠̮̩͎̯̖ͅͅe̡̬̤̙̦̼̟͍̘̖̥̜̗̭͈͕͍̞̞̯͇̞̙͔̻̫͓̞̱̭̞̲̊ͮͦ̽̓̽ͤ̒́̍ͪͣͨ̏̚c̟̥̘̤̙̮̺̝͍͍̺̙͍͉̞͍̥̻̪̖̦̳͇̼̫̲̝͙͍̦̖̫̗͙̞͔̻̖̙͈̘̱̩͇̟̻̫̞̮̯̮̰͚͉̞̒͆̌̐̐̾ͩ́̽̾͐͛̐ͯ͗̓̉͘t͗ͤ͆̆͐ͯͧͬ̋ͧ͑ͬͦ̀ͯ̄͋ ҉̺͔̳̟̣̰̙̳̗̗̻̣͍̥̟͓̯͍͕̣͙̱̘̱̰̱͉̤͚̣̠̱̤̞̗̟͔̲̦̤̲̘̬̺̞͔̯̹̝̥̱͇̪̲ͅͅͅͅ ͇̟̠̗͚͔͍̜̟̲̪̳̻̟̭̬̟̝̠̱̥̫̥̳̳͚͕̣͈̼̼̻̼̱̖͙̭͚͓̗͍̥̞̟̀̆ͥ͒̈ͦ̔͋͝ͅO̜̹̮̭͇͎͓̘̺̹̩̱͚̦̯̞̣̣̼̲͖̱̺̠͙͙̹͉̘̻̖̥͓͍̦̰͈̺̮̜̺̝̭̜̗̺̞̣͕̞̤ͦ̌͊̑̅͆͞ͅb̵̲͎̮̦̣̠͎̤͕̬͇̞̹̞̖̪̦͔͍̞̦̖̘̠̙̯̞̲͈̟̻̰̦̭̼̳̲̩͇̫̬̤̰̃͐̊̄j̴̼͉͇̲̺̺̥̣̱͎̭̫̖͎̖̬̺̞̭͓̥̙̻̜̠͍̤̖̩̙̻̦̪̝̣̣̫̝̩͉̥̯̘̗̯̰͉͉͈̭̅ͯ̓̐̇͒̂̔̊͐ͩͣ̅̿ě̷̦͔͈͙̥͈͙̱͚̠͖̣̺̰̘̝̝̤̱̞̗̮̘̭̬͔̼̟̮͎̱̼̬̙̠̤̲͓̠͉̹̼̫͈̘̯͕̗͚̲͓̼͖̺͍̠͙͍̩̓ͪ̔ͮͅc̛͍͈̝͔̰̹͉̖͚̝̻̆̊̅͆ț̨̼̯̟͇̜͇̱̟̝̫͕̩͎̠̤̯͎̘̳͇̳̞̼ͪ͋ͣ͌ͭͣ̍͌ͧ̽͑̉ͦ̌̎ͫͣ]̡̩͈͍͇̪͈̫ͮͮ͆ͧ͛ͫ̎̄̇̊ͫ͒̓̔ͥ̊́̾̑',\n
silly: '\\u001b[31m[\\u001b[39m\\u001b[33mo\\u001b[39m\\u001b[32mb\\u001b[39m\\u001b[34mj\\u001b[39m\\u001b[35me\\u001b[39m\\u001b[31mc\\u001b[39m\\u001b[33mt\\u001b[39m \\u001b[34mO\\u001b[39m\\u001b[35mb\\u001b[39m\\u001b[31mj\\u001b[39m\\u001b[33me\\u001b[39m\\u001b[32mc\\u001b[39m\\u001b[34mt\\u001b[39m\\u001b[35m]\\u001b[39m',\n input: '\\u001b[30m[object Object]\\u001b[39m',\n verbose: '\\u001b[36m[object Object]\\u001b[39m',\n prompt: '\\u001b[90m[object Object]\\u001b[39m',\n info: '\\u001b[32m[object Object]\\u001b[39m',\n blank: '\\u001b[37m[object Object]\\u001b[39m',\n
data: '\\u001b[90m[object Object]\\u001b[39m',\n help: '\\u001b[36m[object Object]\\u001b[39m',\n
warn: '\\u001b[33m[object Object]\\u001b[39m',\n
debug: '\\u001b[34m[object Object]\\u001b[39m',\n
error: '\\u001b[31m[object Object]\\u001b[39m',\n crit: '\\u001b[31m[object Object]\\u001b[39m',\n id: '599b63483d6966050026189b' }","timestamp":"2017-08-21T22:48:40.730Z"}
質問を作成された新しいオブジェクトを出力します。どのように私はこのコードを修正することができ、データが適切に所望の文書を作成するように?
更新:おそらく私はJavaScriptオブジェクトをJSONオブジェクトに変換する必要がありますか?