我想用ajax发送post请求到laravel的控制器。ajax请求发送两个输入参数,我希望控制器使用第一个参数在数据库中查找列,然后使用第二个输入参数设置name属性。但是我在控制台500(内部服务器错误)中有这个错误消息。
Ajax函数:var $emailInput = $('input[name=eemail]').val();
var $finduser = $('[name=userName]').val();
$.ajax({
type:"POST",
url:'/code/task1/public/editUserAdmin',
data: {
'emailInput' : $emailInput,
'finduser' : $finduser,
},
success:function(data){
// $("#editEmail").attr("readonly", true);
// $("#editEmail").val(data[0].name);
alert("OK");
}
});
路线:
Route::post('/editUserAdmin', 'usersController@editUserAdmin');
控制器功能:$findUserInput = $request->input('finduser');
$user = User::where('name',$findUserInput)->first();
if(!$user){
return response()->json(['status'=>false,'Description' => 'User could not be found.']);
}
//$user->name = $request->input('nameInput');
$user->email = $request->input('emailInput');
$user->save();
}
我也导入csrf无处不在,因为上次我做AJAX调用时,我有这个csrf的问题,下面的代码已经修复了我的问题,但现在不工作。
<meta name="csrf-token" content="{{ csrf_token() }}">
$.ajaxSetup({
headers:{
'X-CSRF-TOKEN' : $('meta[name="csft-token"]').attr('content')
}
});
$.ajaxSetup({
headers: {
'X-CSRF-TOKEN': $('[name="_token"]').val()
}
});
and this
<h3 class="media-heading" name="userName">{{ $user->name }}</h3>
<input type="hidden" name="_token" value="{{ csrf_token() }}">
<input type="text" class="form-control paddingzero" class=text-center" readonly value="Name Name">
<input type="text" class="form-control paddingzero" class=text-center" name="eemail" id="editEmail" readonly value="{{ $user->email }}">
任何想法?
Ajax没有"type"属性。您需要将POST作为方法
传递。$.ajax({
method: "POST",
url:'/code/task1/public/editUserAdmin',
data: {
'emailInput' : $emailInput,
'finduser' : $finduser,
},
success:function(data){
alert("OK");
}
});
如果你在开发模式下,你应该启用错误登录/输出。你可以打开开发工具F12(在chrome中为例),看看错误输出。可能是方法不允许或者其他的。
另一件小事是,如果你不引用jquery对象,我建议不要用$作为实际变量的前缀。
var $emailInput = $('input[name=eemail]').val();
var $finduser = $('[name=userName]').val();
而不是做
var $emailInput = $('input[name=eemail]'); // if you need it more than once
var email = $emailInput.val();
或者如果你只需要它,最好命名为
var emailInput = $('input[name=eemail]').val();