Laravel 解决跨域问题

在进行后台登录时我们遇到了跨域问题。

对于这个问题不是很懂,在网上查找了一段时间,都是使用的中间件,然后进行全局设置。

建立中间件:

server('HTTP_ORIGIN') ? $request->server('HTTP_ORIGIN') : '';
        $allow_origin = [
            'http://localhost:8080',
        ];
        if (in_array($origin, $allow_origin)) {
            $response->header('Access-Control-Allow-Origin', $origin);
            $response->header('Access-Control-Allow-Headers', 'Origin, Content-Type, Cookie, X-CSRF-TOKEN, Accept, Authorization, X-XSRF-TOKEN');
            $response->header('Access-Control-Expose-Headers', 'Authorization, authenticated');
            $response->header('Access-Control-Allow-Methods', 'GET, POST, PATCH, PUT, OPTIONS');
            $response->header('Access-Control-Allow-Credentials', 'true');
        }
        return $response;
    }
}

中间件中的$allow_origin=[];这个根据具体情况修改。

然后我们在app/Http/Kernel.php中注册中间件:

protected $middleware = [
        ............
        \App\Http\Middleware\EnableCrossRequestMiddleware::class,
    ];

 

你可能感兴趣的:(API)