Maybe this is a very common topic, but i can't find any solution!, the app i'm developing is under Laravel 5.0, i need to send some data from jquery ajax to a laravel controller, i've followed this tutorial to post data using ajax, i've followed the steps and made the global configuration, so that i have a meta with the csrf token, when i send the post request to a url using ajax, it just sends the token!! but nothing of the data i give it to send!
Here's my ajax func (i'm using dummy data to test it):
$.ajax( {
url : '/reservacion/paso-uno/enviar',
method : 'post',
data : { name: "John", location: "Boston" }
} );
but when i dd(\Request::all()); in the post func i only get the token, also if i check the headers form data i only get this:
Here's a complete image of the headers:
Here's the meta tag with the csrf:
<meta name="_token" content="{{{ csrf_token() }}}"/>
And here's the global ajax setup:
$.ajaxSetup({
headers: { 'X-CSRF-Token' : $('meta[name=_token]').attr('content') }
});
BIG UPDATE
Don't know why, neither how, i guess it was just a cache problem, but having the above configuration it sends data, but that happens only when i have a <input type='submit' >
and in jquery setup the click event, because if i setup it for the submit event it reloads the page with a query string in the browser path.
Now the problem is that the function of the controller is not reached... when i click on the button nothing happens, data is send but it dont reaches laravel controller.
i hope this will help you.
<meta name="csrf-token" content="{{ csrf_token() }}">
Route::get('/your/url/goes/here',
[
'uses' => 'TestController@testFunction'
]);
on top use Input;
public function iddtest()
{
print_r(Input::all());
}
$.ajax({
data: {data1:'data1',data2:'data2'},
url: '/your/url/goes/here',
type: 'POST',
beforeSend: function (request) {
return request.setRequestHeader('X-CSRF-Token', $("meta[name='csrf-token']").attr('content'));
},
success: function(response){
console.log(response);
}
})
Somewhere in the form add the CSRF Token like this
<meta name="csrf-token" content="{{ csrf_token() }}">
Add a post route
Route::post('/path/to/ajax-form-process', 'FormController@processor');
class FormController extends Controller{
public function processor(Request $request){
$input = $request->all();
//Do other processes
return '200'; //Use any string that is appropriate
}
}
In your JS/jQuery script add the following
$.ajax({
type: "POST",
url: 'path/to/ajax-form-process',
data: {
data1: 'data1',
data2: 'data2',
data3: 'data3'
},
success: function(html){
console.log(html);
}
});
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With