前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Laravel 解决跨域[COS]问题【附CSRF问题】

Laravel 解决跨域[COS]问题【附CSRF问题】

作者头像
无道
发布2019-11-13 16:24:30
9640
发布2019-11-13 16:24:30
举报
文章被收录于专栏:无道编程无道编程

前言

越发觉得发博客是一种好的习惯,因为自己经历过这种坑,影响深刻。并且所附上的解决办法是真实有效的。没办法,哪些csdn之流的,转载来转载去,不能说没用,但很多都失效或过期了。

还有一个好处是:不记录下,就比如现在的我,还要打开以前的项目去看怎么解决的。这比打开博客一搜慢多了。

细节

创建一个中间件

EnableCrossRequestMiddleware

代码语言:javascript
复制
php artisan make:middleware EnableCrossRequestMiddleware
截图-1569242646
截图-1569242646
编辑其handle方法
代码语言:javascript
复制
$response = $next($request);
$response->header('Access-Control-Allow-Origin', '*')->header('Access-Control-Allow-Headers', '*');
return $response;
截图-1569242752
截图-1569242752

注意:我这里是直接指定*,因为我的服务也是比较开放的,不存在什么要求。有要求的要自己设定允许的Origin和Headers

注册中间件

位置:app/Http/Kernel.php

在路由中间件中添加:

代码语言:javascript
复制
'cos.check' => \App\Http\Middleware\EnableCrossRequestMiddleware::class
截图-1569242893
截图-1569242893
使用

在定义路由是,添加一个middlerware即可:

截图-1569242930
截图-1569242930

其中cos.check名称,就是上一步在kernel文件中注册的名称,自定义即可。

附解决CSRF问题

csrf问题,我有时候需要使用ajax post一些数据。网上说的新建中间件还是什么解决办法,我觉得都不好使。

这里有一个解决办法:

在文件app/Http/Middleware/VerifyCsrfToken.php有一个except数组:

截图-1569329805
截图-1569329805

里面填写不需要的路径,如上就代表http://test.com/api/importTmpUrl这条URL不适用CSRF验证。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019-09-23,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 前言
  • 细节
    • 创建一个中间件
      • 编辑其handle方法
        • 注册中间件
          • 使用
          • 附解决CSRF问题
          相关产品与服务
          消息队列 TDMQ
          消息队列 TDMQ (Tencent Distributed Message Queue)是腾讯基于 Apache Pulsar 自研的一个云原生消息中间件系列,其中包含兼容Pulsar、RabbitMQ、RocketMQ 等协议的消息队列子产品,得益于其底层计算与存储分离的架构,TDMQ 具备良好的弹性伸缩以及故障恢复能力。
          领券
          问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档