首页 文章

Ajax中的Laravel 5 X-CSRF-TOKEN 500(内部服务器错误)

提问于
浏览
1

您好我使用Ajax更改密码(这是代码的简短版本):

var password = document.querySelector('[name="password"]').value;

    action = 'http://localhost:8012/market2/market2/public/account/query/';

    if (window.XMLHttpRequest) {
      xmlhttp = new XMLHttpRequest(); // code for IE7+, Firefox, Chrome, Opera, Safari
    } else {
      xmlhttp = new ActiveXObject("Microsoft.XMLHTTP"); // code for IE6, IE5
    }

    xmlhttp.open("post",action + password, true);
    xmlhttp.setRequestHeader("X-CSRF-TOKEN", document.getElementById('token-csrf').value);

    xmlhttp.onreadystatechange=function() {
      if (this.readyState == 4 && this.status == 200) {

        if (this.responseText == "false") {
            document.getElementById("error_password").innerHTML = "You actually password is wrong!";
            return false;
        } else {
            document.getElementById("error_password").innerHTML = "OK";
            return true;
        }

      }
    }


    xmlhttp.send();

}

我的csrf-token: <input type="hidden" name="_token" id="token-csrf" value="{{ csrf_token() }}">

我不知道我是否正确添加参数 X-CSRF-TOKEN 到我的脚本 . 首先我有错误 ajax 419 (unknown status) 所以我添加 X-CSRF-TOKEN 现在我有错误 500 (Internal Server Error) . 我也尝试过这个:Laravel 5.5 ajax call 419 (unknown status)

编辑帖子:

不是我的查询方法:

public function queryPass($pass) {

  $user = Auth::user();
  $current_password = $user->password;

  if(Hash::check($pass, $current_password)) {

    $updatePassword = App\User::where('id', $user->id)->update(['password' => bcrypt($pass)]);
    echo "true";

  } else {

    echo "false";
    die;

  }

}

路线:

Route::get('account/query/{pass?}', 'UsersController@queryPass');

1 回答

  • 1

    第一个问题是他在控制器的顶部错过了 use Illuminate\Support\Facades\Hash; ,他使用了 use Hash; ,当我们解决的第二件事是,他从控制器内部返回一个布尔值,当他应该返回一个实现 __toString 方法的对象时一个字符串,所以他返回了一个正确的响应,在这种情况下是一个字符串"true"和"false"

相关问题