首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >CORS要求提供laravel-5.5

CORS要求提供laravel-5.5
EN

Stack Overflow用户
提问于 2018-03-15 08:02:48
回答 2查看 996关注 0票数 1
  1. 当通过ajax到API发出post请求时,我得到了419个未知状态。
  2. 我知道这个问题是因为CORS的要求。我在客户端添加了它,但是否也需要从API设置请求头、允许来源等?如果是,如何在API中包括响应头?

备注 根据laravel-5.5的文档,我已经包含了所有的令牌内容,内部请求工作得很好,我正在使用AJAX。

EN

回答 2

Stack Overflow用户

发布于 2018-06-26 09:37:19

我终于解决了。我用web.php定义了我的api路由,而不是路由/api.php,现在一切都很完美,没有任何错误。

票数 1
EN

Stack Overflow用户

发布于 2018-03-15 09:40:15

Laravel返回一个419错误,通常是当CSRF验证失败时。这听起来像你的问题,因为你提出了一个帖子请求。

确保将CSRF令牌添加到请求中。如果您使用的是jQuery,您可以这样做:

代码语言:javascript
复制
$.ajaxSetup({
    headers: {
        'X-CSRF-TOKEN': $('meta[name="csrf-token"]').attr('content')
    }
});

请确保将此添加到<head>标记中:

代码语言:javascript
复制
<meta content="{{ csrf_token() }}" name="csrf-token" />

编辑

我做了一些研究,我很确定这是CSRF令牌丢失了。

在Laravel中返回419状态代码的唯一地方是这里:Exceptions/Handler.php。如果再深入一点,您会发现抛出TokenMismatchException的唯一地方是VerifyCsrfToken。所以,要么CSRF令牌丢失了,要么它错了。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/49294209

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档