首页 >后端开发 >php教程 >是什么导致 Laravel 中 POST 和 PUT 方法出现 419 状态代码?

是什么导致 Laravel 中 POST 和 PUT 方法出现 419 状态代码?

Linda Hamilton
Linda Hamilton原创
2024-10-18 20:37:03288浏览

What Causes the 419 Status Code in Laravel for POST and PUT Methods?

了解 Laravel API 中 POST 和 PUT 方法的 419 状态代码

使用 Laravel 开发 RESTful API 时,经常会遇到 419 POST 和 PUT 方法的状态代码。此错误是由于 Laravel 的 CSRF 令牌验证过程造成的。

在 Laravel 5.4 及更早版本中,所有请求都启用 CSRF 令牌,包括 POST 和 PUT 方法。这是为了保护应用程序免受跨站点请求伪造 (CSRF) 攻击。默认情况下,CSRF 令牌作为表单中的隐藏字段添加到视图中。

提交 POST 或 PUT 请求时,Laravel 期望收到有效的 CSRF 令牌以及请求数据。如果未找到有效令牌,Laravel 会生成“419 CSRF 令牌不匹配”异常并返回 419 状态代码响应。

从 CSRF 保护中排除路由

至要解决此问题,您可以从 CSRF 令牌验证中排除某些路由。在 Laravel 5.5 及以上版本中,您可以使用 api.php 文件代替 web.php 进行 API 路由,并且默认情况下不启用 CSRF 验证。

如果您使用 web.php 进行 API 路由,则可以通过将它们的 URI 添加到VerifyCsrfToken 中间件的 $ except 属性来将它们排除在 CSRF 令牌验证之外。例如:

<code class="php">namespace App\Http\Middleware;

use Illuminate\Foundation\Http\Middleware\VerifyCsrfToken as BaseVerifier;

class VerifyCsrfToken extends BaseVerifier
{
    protected $except = [
        '/api/*',
    ];
}</code>

这将从 CSRF 令牌验证中排除所有以 /api 开头的路由。

非 API 路由的替代解决方案

如果不适合从 CSRF 保护中排除路由,您可以对路由组内的特定方法禁用 CSRF 验证。例如:

<code class="php">Route::group(['middleware' => 'web'], function () {
    Route::post('/my-route', 'MyController@store')->withoutMiddleware('verify-csrf-token');
});</code>

这将禁用对 /my-route 的 POST 请求的 CSRF 令牌验证。

以上是是什么导致 Laravel 中 POST 和 PUT 方法出现 419 状态代码?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn