小编tre*_*gan的帖子

Laravel 5 Auth Post提交 - VerifyCsrfToken.php第46行中的TokenMismatchException

刚刚在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)

php forms laravel-5

30
推荐指数
4
解决办法
5万
查看次数

标签 统计

forms ×1

laravel-5 ×1

php ×1