![](/img/trans.png)
[英]How to pass data from ajax to laravel 5.2 controller via post method
[英]Pass JSON data from AngularJS to Laravel Controller via POST
我正在使用AngularJS将数据发布到Laravel控制器,然后将其保存到数据库。
我遇到了一个问题,其中我从AngularJS传递到Laravel的数据未正确解析。
这是我正在传递的数据:
$scope.invoice_items = [
{
quantity: '1',
price_per: '30',
price_total: '30'
},
{
quantity: '2',
price_per: '5',
price_total: '10'
}
];
这是我的功能:
$scope.createInvoice = function () {
invoiceService.save($scope.invoice_items).success(function(somedata) {
alert('successful!');
console.log(somedata);
}).error(function(data) {
alert('not successful');
console.log(data)
});
};
这是发送数据的服务:
save: function(invoiceData) {
return $http({
method: 'POST',
url: 'http://localhost/blahblah',
headers: { 'Content-Type' : 'application/x-www-form-urlencoded' },
data: $.param(invoiceData)
});
}
这是我的Laravel控制器:
public function store() {
$input = request::all();
return $input;
}
最后,该$ input仅返回:
Object {undefined: ""}
所以我的问题是。 如何将invoice_items中的数据传递到laravel控制器中,以便显示如下内容:
invoice_items = [
{
quantity: '1',
price_per: '30',
price_total: '30'
},
{
quantity: '2',
price_per: '5',
price_total: '10'
}
];
然后,我可以在Laravel控制器中执行foreach来做我想做的任何事情。
最终,我想在我的laravel控制器中执行以下操作:
foreach(invoice_items as item) {
echo item->quantity;
}
我希望这是有道理的。 有人对我如何实现这一目标有想法吗?
其实我想通了!
我所做的修改是在Angular Service中进行的:
data: invoiceService
那没有$ .param ..
在Laravel控制器中,我所做的就是:
return file_get_contents('php://input')
那行得通!
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.