通过POST将AngularJS中的JSON数据传递给Laravel Controller

时间:2015-10-07 19:23:39

标签: javascript php json angularjs laravel

我使用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;
}

我希望这是有道理的。 任何人都知道我如何才能做到这一点?

1 个答案:

答案 0 :(得分:0)

其实我弄清楚了!

我所做的修改是在Angular Service中:

data: invoiceService

没有$ .param ..

在Laravel控制器中,我所做的只是:

return file_get_contents('php://input')

这很有效!