簡體   English   中英

是什么原因導致此 Laravel 8 應用程序出現“419 未知狀態”錯誤?

[英]What causes the "419 unknown status" error in this Laravel 8 application?

我正在用 Laravel 8 和 Bootstrap 5 制作一個博客應用程序。它有一個用戶配置文件管理系統。

我想讓每個用戶都可以添加和刪除她/他的頭像 為此,我在我的UserController controller 中有一個deleteavatar()方法:

public function deleteavatar($id, $fileName)
{
  $current_user = Auth::user();
  $current_user->avatar = "default.png";
  $current_user->save();

  if (File::exists(public_path('images/avatars/' . $fileName))) {
    File::delete(public_path('images/avatars/' . $fileName));
  }
}

在路由文件中:

Route::group(['prefix' => 'user'], function() {
    Route::get('/', [UserController::class, 'index'])->name('user');
    Route::match(['get', 'post'],'/update', [UserController::class, 'update'])->name('user.update');
    Route::post('/deleteavatar/{id}/{fileName}', [UserController::class, 'deleteavatar'])->name('user.deleteavatar');
});

我用這塊JavaScript來調用上面的方法:

function deleteAvatar(e) {
    e.preventDefault();

    var avatar = document.querySelector('#avatar-container img');
    var topAvatar = document.querySelector('#top_avatar');
    var trashIcon = e.currentTarget;
    var defaultAvatar = APP_URL + '/images/avatars/default.png';

    //Get user's ID
    var id = trashIcon.dataset.uid;
    var fileName = avatar.getAttribute('src').split('/').reverse()[0];

    var url = APP_URL + `/dashboard/user/deleteavatar/${id}/${fileName}`;

    if (confirm('Delete the avatar?')) {
      var CSRF_TOKEN = document.querySelectorAll('meta[name="csrf-token"]')[0].getAttribute('content');

      var xmlhttp = new XMLHttpRequest();
      xmlhttp.onreadystatechange = function() {
        if (xmlhttp.readyState == XMLHttpRequest.DONE) { 
          if (xmlhttp.status == 200) {
              avatar.setAttribute('src', defaultAvatar);
              topAvatar.setAttribute('src', defaultAvatar);
              trashIcon.remove();
          }
        }
      }

      xmlhttp.open('POST', url, true);
      xmlhttp.send();
    }
}
document.querySelector('#delete-avatar').addEventListener('click', deleteAvatar);

問題

由於我一直無法找到的原因,Chrome 控制台拋出這個419 (unknown status)

我的錯誤是什么?

由於缺少 csrf 令牌,Laravel 正在返回 http 狀態 419。 在 HTML meta標記中添加 csrf 令牌,並添加到您的 ajax 請求 header。

供參考: https://laravel.com/docs/8.x/csrf#csrf-x-csrf-token

為 csrf 令牌設置 xmlhttp header

function deleteAvatar(e) {
    e.preventDefault();

    var avatar = document.querySelector('#avatar-container img');
    var topAvatar = document.querySelector('#top_avatar');
    var trashIcon = e.currentTarget;
    var defaultAvatar = APP_URL + '/images/avatars/default.png';

    //Get user's ID
    var id = trashIcon.dataset.uid;
    var fileName = avatar.getAttribute('src').split('/').reverse()[0];

    var url = APP_URL + `/dashboard/user/deleteavatar/${id}/${fileName}`;

    if (confirm('Delete the avatar?')) {
        var CSRF_TOKEN = document.querySelectorAll('meta[name="csrf-token"]')[0].getAttribute('content');

        var xmlhttp = new XMLHttpRequest();

        xmlhttp.onreadystatechange = function() {
            if (xmlhttp.readyState == XMLHttpRequest.DONE) { 
                if (xmlhttp.status == 200) {
                        avatar.setAttribute('src', defaultAvatar);
                        topAvatar.setAttribute('src', defaultAvatar);
                        trashIcon.remove();
                }
            }
        }

        xmlhttp.open('POST', url, true);
        xmlhttp.setRequestHeader("X-CSRF-TOKEN", CSRF_TOKEN);
        xmlhttp.send();
    }
}
document.querySelector('#delete-avatar').addEventListener('click', deleteAvatar);

參考: https://developer.mozilla.org/en-US/docs/Web/API/XMLHttpRequest/setRequestHeader

參考: https://laravel.com/docs/9.x/csrf

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM