我在POST路由中遇到Laravel 5.4的問題。Laravel 5.4 TokenMismatchException(Chrome)
當提交表單時,顯示錯誤TokenMismatchException。
我認爲這是關於PrefixVariable,所以我在Github上打開了this issue。但經過太多的測試並嘗試不同的解決方案後,我發現問題不是由Prefix制定的。
Firefox中的所有內容都正常,主要問題出現在Chrome中。郵局路由僅在提交第一個表單後,所有接下來的請求到同一個URL表面TokenMismatchException錯誤。
我已經試過如下:
- 清除瀏覽器cookies和歷史記錄
- 運行
php artisan cache:clear
命令 - 更改即成端口
- 防止緩存PHP中的頭
- 防止緩存在HTML與Meta Tags
但問題依然存在。
究竟是什麼錯誤?如果你能幫助我,我將不勝感激。
登錄表單:
<form method="post" action="{{route('login')}}">
{!! csrf_field() !!}
<div class="row">
<div class="col-xs-12">
<div class="form-group no-margin">
<div class="col-xs-6 col-md-10 col-md-offset-1">
<input name="username" type="text" class="form-control" placeholder="نام کاربری" value="{{old('username')}}">
</div>
</div>
<div class="form-group no-margin">
<div class="col-xs-6 col-md-10 col-md-offset-1">
<input name="password" type="password" class="form-control" placeholder="کلمه عبور">
</div>
</div>
</div>
<div class="col-xs-12">
<div class="form-group no-margin">
<div class="col-xs-5 col-md-offset-1">
<input name="captcha" type="text" class="form-control" placeholder="کپچا">
</div>
<div class="col-xs-5 no-pad-right">
<img src="{{captcha_src('flat')}}" class="img-responsive">
</div>
</div>
</div>
<div class="col-xs-12 text-center">
<div class="form-group">
<button type="submit" class="btn btn-success btn-raised">ورود<div class="ripple-container"></div></button>
<button type="reset" class="btn btn-danger btn-raised">انصراف<div class="ripple-container"></div></button>
</div>
</div>
</div>
</form>
web.php
Route::group(['prefix' => config('system.ADMIN_PATH'), 'namespace' => 'Panel'], function(){
Route::get('/', function(){return redirect()->route('login');});
Route::get('/auth', '[email protected]')->name('login');
Route::post('/auth', '[email protected]')->name('check');
});
AuthController.php:
namespace App\Http\Controllers\Panel;
use Illuminate\Http\Request;
use Illuminate\Routing\Controller;
class AuthController extends Controller
{
public function Login(Request $request)
{
header("Cache-Control: no-store, no-cache, must-revalidate, max-age=0");
header("Cache-Control: post-check=0, pre-check=0", false);
header("Pragma: no-cache");
return view('admin.login');
}
public function Auth(Request $request)
{
header("Cache-Control: no-store, no-cache, must-revalidate, max-age=0");
header("Cache-Control: post-check=0, pre-check=0", false);
header("Pragma: no-cache");
dump($request->all());
echo "Received";
}
}
這些標題的目的是什麼? –
@TobyMellor只是防止緩存。沒有標題的輸出沒有區別。 –