POST 500(内部服务器错误)Ajax


POST 500 (Internal Server Error) Ajax

我想用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();