У меня проблема с ожидающими $ http.post запросами от angularjs, чтобы выразить при попытке отправить сообщение в mongodb. Мой app.js:
app.use(express.favicon());
app.use(express.logger('dev'));
app.use(express.static(__dirname + '/public'));
app.use('/bower_components', express.static(__dirname + '/bower_components'));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: true }));
app.use(express.methodOverride());
app.use(app.router);
Мой route.js для сообщения:
self.routeTable.push({
requestType : 'post',
requestUrl : '/getAllPrjProjections',
callbackFunction : function (request, response) {
console.log(request.body.pr_code);
console.log(request.body.high_low);
console.log(request.body);
var prjProjectionsDao = require('../Server/Dao/prjProjectionsDao.js');
prjProjectionsDao.create({
pr_code : request.body.pr_code,
high_low : request.body.high_low,
subs_rate : request.body.subs_rate,
prj_month : request.body.prj_month,
prj_value : request.body.prj_value,
last_saved : request.body.last_saved
}, function(err, todo) {
console.log(todo);
if (err) {
console.log('bbb');
response.send(err);
}
});
}
});
В контроллере я реализую функцию ниже, когда пользователь нажимает кнопку saveProjections:
$scope.saveProjections = function() {
$scope.prj_to_save = {"pr_code":"PGU","high_low":"HIGH","subs_rate":"Paid Subs","prj_month":"2016-10-01","prj_value":"96000","last_saved":"2016-12-07"};
var data_to_send = JSON.stringify($scope.prj_to_save);
prjProjectionsService.saveProjections($scope.prj_to_save).then(function(success) {
// $scope.formData = {};
console.log(data, 'Blog created.');
},function (error) {
console.log("The request failed: " + error.data);
});
};
и инжектируемый сервер:
function saveProjections(prjData){
return $http.post('/getAllPrjProjections', prjData).then(function (success) {
console.log('success');
}, function (error) {
console.log('error');
});
}
Проблема заключается в том, что запрос остается в ожидающем состоянии в течение длительного времени (прикрепленный принтерный принтер), а затем он терпит неудачу с ошибкой: "XMLHttpRequest: ошибка сети 0x2ef3, не удалось завершить операцию из-за ошибки 00002ef3"
Однако данные публикуются в mongodb. Не могли бы вы помочь мне? Буду весьма признателен за это.
Вы отправляете ответ только в случае ошибки, так что отправляйте что-то в случае успеха
function(err, todo) {
console.log(todo);
if (!err) return response.send(todo); // or send whatever or respnose.end()
console.log('bbb');
response.send(err);
});