我正在嘗試使用 ajax 在 laravel 中提交表單,該表單具有一些輸入型別和上傳檔案選項。提交表格后,我收到一個錯誤 -
{message: "CSRF token mismatch.", exception: "Symfony\Component\HttpKernel\Exception\HttpException",…}exception: "Symfony\Component\HttpKernel\Exception\HttpException"file: "D:\development\laravel\parangatcrm\vendor\laravel\framework\src\Illuminate\Foundation\Exceptions\Handler.php"line: 389message: "CSRF token mismatch."
I have added this in my blade file -
<meta name="csrf-token" content="{{ csrf_token() }}">
<input type="hidden" name="csrf-token" value="{{ csrf_token() }}">
This is my ajax code -
$.ajax({
url: url,
type: 'PATCH',
data: new FormData($("#formId")[0]),
cache : false,
processData: false,
contentType: false,
success: function (res){
console.log(res);
}
,error: function (err){
console.log(err);
}
});
uj5u.com熱心網友回復:
您需要在標頭上發送 csrf 令牌,而不是與表單資料一起發送。在你的代碼上嘗試這樣的事情:
要為每個請求添加默認標頭,請使用 $.ajaxSetup():
$.ajaxSetup({
headers: {
'X-CSRF-Token': $('meta[name="csrf-token"]').attr('content')
}
});
或者你可以像下面的代碼一樣添加標題:
$.ajax({
url: url,
headers: { 'X-CSRF-Token': ('meta[name="csrf-token"]').attr('content') }
type: 'PATCH',
data: new FormData($("#formId")[0]),
cache : false,
processData: false,
contentType: false,
success: function (res){
console.log(res);
}
,error: function (err){
console.log(err);
}
});
轉載請註明出處,本文鏈接:https://www.uj5u.com/shujuku/456341.html
