AngularJS $resource 的跟进在使用方法时调用了错误的 API URL:POST
我的控制器是这样设置的,使用 Angular 的$resource
:
$scope.updateProduct = $resource('/api/updateProduct/:product/:param/:value',{},{
query: {method:'GET'},
post: {method:'POST'},
save: {method:'PUT', params: {brand: '@brand', param:'@param', value:'@value'}},
remove: {method:'DELETE'}
});
$scope.updateProduct.save({
product : $scope.post._id,
param: 'likes',
value: $scope.user._id
});
我的服务器在NodeJS
和上运行ExpressJS
。在我的控制台中,当save
调用操作时,我可以看到:
POST /api/updateBrand/<productid>/likes/fun,%20quirky%20loud,%20boho,%20hippy 200 22ms - 2.31kb
但是,我的 API 没有被正确访问。例如,如果我在浏览器中访问上述 URL,则调用 API 函数,并更新我的数据库(并在我的服务器控制台中报告)。然而,当 AngularPUT
在这个 URL 上做 a 时,什么都没有发生。
有趣的是,当我更改$scope.updateProduct.save()
为时$scope.updateProduct.get()
,API 被正确调用并且一切正常。
有什么想法吗?
编辑:这是服务器设置:
ExpressJS
API设置:
app.get('/api/updateProduct/:product/:param/:value', api.updateProduct);
API code
exports.updateProduct = function (req, res) {
console.log("TEST")
var product = req.params.product;
var param = req.params.param;
var value = req.params.value;
var props = { $push: {} };
if(param == 'userTags'){
var oldVal = value;
value = oldVal.match(/[-'"\w]+/g);
props.$push[param];
props.$push[param] = {$each: []};
props.$push[param].$each = value;
}else{
var props = { $push: {} };
props.$push[param] = value;
}
db.products.update({"_id": ObjectId(product)}, props, function (err, record) {
if (err || !(record)) {
console.log("Lookup Error: " + err);
} else{
console.log("Updated " + product + " with " + param);
console.log(record);
res.json({obj:record})
}
});
};