刚刚在Laravel 5中创建了一个新的应用程序,我在使用开箱即用的auth时遇到了一些麻烦......
我一直得到:VerifyCsrfToken.php第46行中的TokenMismatchException:提交登录或注册表单...
我可以在登录表单页面上看到隐藏表单字段中的令牌代码和该点的Session是相同的...
作为一个测试我也试过,因为一些其他帖子建议在app/Http/kernal.php中评论//'App\Http\Middleware\VerifyCsrfToken'以查看会发生什么.每次提交表单后,我都会收到一条消息,说明重定向到:/ auth/login或/ auth/register,具体取决于我来自哪里但没有成功.
奇怪的是,当我第一次安装框架时,这是有效的.从那时起我所做的就是运行一些迁移并设置我的一些模型和控制器,并在数据库中添加一些用户数据.
更新:
如果我:在VerifyCsrfToken.php的第55行的函数tokensMatch()中进一步研究这个:
var_dump($request->session()->token());
var_dump($request->input('_token'));
Run Code Online (Sandbox Code Playgroud)
我可以看到两个令牌不同但在表格中使用:
var_dump(Session::all());
{{{ csrf_token() }}}
Run Code Online (Sandbox Code Playgroud)
他们是一样的.会话令牌在它到达VerifyCsrfToken.php第55行的函数tokensMatch()之前已经改变了一些方法.
我的堆栈跟踪如下:
in VerifyCsrfToken.php line 46
at VerifyCsrfToken->handle(object(Request), object(Closure)) in VerifyCsrfToken.php line 17
at VerifyCsrfToken->handle(object(Request), object(Closure)) in Pipeline.php line 125
at Pipeline->Illuminate\Pipeline\{closure}(object(Request)) in ShareErrorsFromSession.php line 55
at ShareErrorsFromSession->handle(object(Request), object(Closure)) in Pipeline.php line 125
at Pipeline->Illuminate\Pipeline\{closure}(object(Request)) in StartSession.php line 61
at StartSession->handle(object(Request), object(Closure)) in Pipeline.php line 125
at Pipeline->Illuminate\Pipeline\{closure}(object(Request)) in AddQueuedCookiesToResponse.php line 36
at AddQueuedCookiesToResponse->handle(object(Request), object(Closure)) in Pipeline.php line 125
at Pipeline->Illuminate\Pipeline\{closure}(object(Request)) in EncryptCookies.php …Run Code Online (Sandbox Code Playgroud)