>  기사  >  PHP 프레임워크  >  미들웨어를 사용하여 Laravel에서 CORS(교차 원본 리소스 공유)를 구현하는 방법

미들웨어를 사용하여 Laravel에서 CORS(교차 원본 리소스 공유)를 구현하는 방법

WBOY
WBOY원래의
2023-11-02 13:57:281442검색

미들웨어를 사용하여 Laravel에서 CORS(교차 원본 리소스 공유)를 구현하는 방법

미들웨어를 사용하여 Laravel에서 CORS(Cross-Origin Resource Sharing)를 구현하는 방법

개요:

CORS(Cross-Origin Resource Sharing)는 웹 애플리케이션이 다른 도메인 이름에서 실행될 수 있도록 하는 데 사용되는 브라우저 메커니즘입니다. 아래 리소스. 널리 사용되는 PHP 프레임워크인 Laravel은 미들웨어를 사용하여 도메인 간 요청을 처리함으로써 CORS를 처리하는 편리한 방법을 제공합니다.

이 글에서는 미들웨어 구성, 허용된 도메인 이름 및 요청 방법 설정, 구체적인 코드 예제 제공 등 미들웨어를 사용하여 Laravel에서 CORS를 구현하는 방법을 소개합니다.

1단계: CORS 미들웨어 생성

먼저 CORS를 처리할 미들웨어를 생성해야 합니다. 새 미들웨어 파일을 생성하려면 터미널에서 다음 명령을 사용하세요:

php artisan make:middleware CorsMiddleware

이 명령은 app/Http/Middleware 디렉터리 CorsMiddleware에 라는 파일을 생성합니다. .php 파일. app/Http/Middleware目录下生成一个名为CorsMiddleware.php的文件。

打开CorsMiddleware.php文件,修改handle方法如下:

public function handle($request, Closure $next)
{
    $response = $next($request);
    
    $response->header('Access-Control-Allow-Origin', '*');
    $response->header('Access-Control-Allow-Methods', 'GET, POST, PUT, DELETE, OPTIONS');
    $response->header('Access-Control-Allow-Headers', 'Content-Type, Authorization');
    
    return $response;
}

在这个中间件中,我们设置了三个响应头,分别是:Access-Control-Allow-OriginAccess-Control-Allow-MethodsAccess-Control-Allow-HeadersAccess-Control-Allow-Origin允许所有源进行跨域访问,您也可以根据需要设置特定的域名。Access-Control-Allow-Methods定义允许的请求方法,这里我们设置了常见的GET、POST、PUT、DELETE和OPTIONS。Access-Control-Allow-Headers允许的请求头中包含了Content-Type和Authorization。

步骤二:注册CORS中间件

打开app/Http/Kernel.php文件,找到$middleware数组,并在数组中添加以下行代码:

protected $middleware = [
    // ...
    AppHttpMiddlewareCorsMiddleware::class,
];

以上代码将添加CorsMiddleware中间件到全局中间件堆栈中,以便它可以应用于每一个请求。

步骤三:使用CORS中间件

为了验证我们的CORS中间件是否有效,我们可以在一个API路由中使用它。在routes/api.php文件中,添加一个GET路由,并为该路由使用CorsMiddleware中间件:

Route::get('/test', function () {
    return response()->json(['message' => 'Hello World']);
})->middleware('cors');

这个路由将返回一个包含"Hello World"消息的JSON响应。

步骤四:验证CORS设置

现在我们可以使用任何支持跨域访问的客户端,例如浏览器或REST客户端进行验证。在浏览器的开发工具中,我们可以看到响应的头部信息。

例如,在Chrome浏览器上,打开开发者工具,切换到"Network"选项卡,然后访问我们在步骤三中定义的路由/api/test。在响应头部信息中,我们应该看到Access-Control-Allow-OriginAccess-Control-Allow-MethodsAccess-Control-Allow-Headers

CorsMiddleware.php 파일을 열고 handle 메서드를 다음과 같이 수정합니다.

rrreee

이 미들웨어에서는 세 가지 응답 헤더를 설정합니다. 액세스 -Control-Allow-Origin, Access-Control-Allow-MethodsAccess-Control-Allow-Headers. Access-Control-Allow-Origin은 모든 소스의 도메인 간 액세스를 허용하며 필요에 따라 특정 도메인 이름을 설정할 수도 있습니다. Access-Control-Allow-Methods는 허용되는 요청 방법을 정의합니다. 여기서는 일반적인 GET, POST, PUT, DELETE 및 OPTIONS를 설정합니다. Access-Control-Allow-Headers의 허용되는 요청 헤더에는 Content-Type 및 Authorization이 포함됩니다.

2단계: CORS 미들웨어 등록

app/Http/Kernel.php 파일을 열고 $middleware 배열을 찾은 다음 array: 🎜 rrreee🎜위 코드는 CorsMiddleware 미들웨어를 전역 미들웨어 스택에 추가하여 모든 요청에 ​​적용할 수 있도록 합니다. 🎜🎜3단계: CORS 미들웨어 사용 🎜🎜CORS 미들웨어가 유효한지 확인하려면 API 경로에서 이를 사용할 수 있습니다. routes/api.php 파일에서 GET 경로를 추가하고 이 경로에 대해 CorsMiddleware 미들웨어를 사용하세요. 🎜rrreee🎜이 경로는 "Hello World"가 포함된 메시지를 반환합니다. 메시지의 JSON 응답입니다. 🎜🎜4단계: CORS 설정 확인🎜🎜이제 확인을 위해 브라우저나 REST 클라이언트 등 도메인 간 액세스를 지원하는 모든 클라이언트를 사용할 수 있습니다. 브라우저의 개발 도구에서 응답 헤더 정보를 볼 수 있습니다. 🎜🎜예를 들어 Chrome 브라우저에서 개발자 도구를 열고 "네트워크" 탭으로 전환한 다음 3단계에서 정의한 /api/test 경로에 액세스합니다. 응답 헤더에 Access-Control-Allow-Origin, Access-Control-Allow-MethodsAccess-Control-Allow-Headers가 표시되어야 합니다. 코드> 설정. 🎜🎜모든 것이 정상이라면 다른 도메인 이름에서 HTTP 요청을 보내고 성공적으로 응답을 받을 수 있어야 합니다. 🎜🎜결론: 🎜🎜미들웨어를 사용하여 Laravel 프레임워크는 도메인 간 리소스 공유를 달성하는 쉬운 방법을 제공합니다. 이 문서에서는 CORS 미들웨어를 만들고, 미들웨어를 등록하고, 미들웨어를 사용하여 도메인 간 요청을 처리하는 방법을 자세히 설명합니다. 이 글이 Laravel에서 CORS를 구현하는 데 도움이 되기를 바라며 참조할 수 있는 충분한 코드 예제를 제공합니다. 🎜

위 내용은 미들웨어를 사용하여 Laravel에서 CORS(교차 원본 리소스 공유)를 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.