duanbei7035 2015-12-14 23:15
浏览 374
已采纳

对Lumen上的特定路由禁用CSRF TokenMismatch

I'm using Lumen Framework.

I have an external program who send a HTTP POST request every 2 minutes.

I don't need any views, so I would like to understand how disable CSRF TokenMismatch in Lumen for specific routes (I need it to be activated on some others) ?

  • 写回答

1条回答 默认 最新

  • duanjianao0592 2015-12-14 23:34
    关注

    You could extend the VerifyCsrfToken class and add your routes to the excludes list.

    Add this file called VerifyCsrfToken.php to app/Http/Middleware:

    <?php namespace App\Http\Middleware;
    
    use Closure;
    use Illuminate\Session\TokenMismatchException;
    
    class VerifyCsrfToken extends \Illuminate\Foundation\Http\Middleware\VerifyCsrfToken {
    
        protected $except_urls = [
            // your excluded URLs go here
            'example/route',
        ];
    
        public function handle($request, Closure $next)
        {
            $regex = '#' . implode('|', $this->except_urls) . '#';
    
            if ($this->isReading($request) || $this->tokensMatch($request) || preg_match($regex, $request->path()))
            {
                return $this->addCookieToResponse($request, $next($request));
            }
    
            throw new TokenMismatchException;
        }
    
    }
    

    Then add the Middleware to the bootstrap/app.php file. You have to uncomment $app->middleware() then add it to it like this:

    $app->routeMiddleware([
    'csrf' => 'Laravel\Lumen\Http\Middleware\VerifyCsrfToken',
    ]);
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 sqlite 附加(attach database)加密数据库时,返回26是什么原因呢?
  • ¥88 找成都本地经验丰富懂小程序开发的技术大咖
  • ¥15 如何处理复杂数据表格的除法运算
  • ¥15 如何用stc8h1k08的片子做485数据透传的功能?(关键词-串口)
  • ¥15 有兄弟姐妹会用word插图功能制作类似citespace的图片吗?
  • ¥200 uniapp长期运行卡死问题解决
  • ¥15 请教:如何用postman调用本地虚拟机区块链接上的合约?
  • ¥15 为什么使用javacv转封装rtsp为rtmp时出现如下问题:[h264 @ 000000004faf7500]no frame?
  • ¥15 乘性高斯噪声在深度学习网络中的应用
  • ¥15 关于docker部署flink集成hadoop的yarn,请教个问题 flink启动yarn-session.sh连不上hadoop,这个整了好几天一直不行,求帮忙看一下怎么解决