当前位置: 首页 > 工具软件 > laravel-nuxt > 使用案例 >

Laravel 解决跨域问题

郑卜鹰
2023-12-01

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

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

建立中间件:

<?php

namespace App\Http\Middleware;

use Closure;

class EnableCrossRequestMiddleware
{
    /**
     * Handle an incoming request.
     *
     * @param  \Illuminate\Http\Request  $request
     * @param  \Closure  $next
     * @return mixed
     */
    public function handle($request, Closure $next)
    {
        $response = $next($request);
        $origin = $request->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,
    ];

 

 类似资料: