미들웨어를 사용하여 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-Origin
、Access-Control-Allow-Methods
和Access-Control-Allow-Headers
。Access-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-Origin
、Access-Control-Allow-Methods
和Access-Control-Allow-Headers
CorsMiddleware.php
파일을 열고 handle
메서드를 다음과 같이 수정합니다. rrreee
이 미들웨어에서는 세 가지 응답 헤더를 설정합니다. 액세스 -Control-Allow-Origin
, Access-Control-Allow-Methods
및 Access-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-Methods
및 Access-Control-Allow-Headers
가 표시되어야 합니다. 코드> 설정. 🎜🎜모든 것이 정상이라면 다른 도메인 이름에서 HTTP 요청을 보내고 성공적으로 응답을 받을 수 있어야 합니다. 🎜🎜결론: 🎜🎜미들웨어를 사용하여 Laravel 프레임워크는 도메인 간 리소스 공유를 달성하는 쉬운 방법을 제공합니다. 이 문서에서는 CORS 미들웨어를 만들고, 미들웨어를 등록하고, 미들웨어를 사용하여 도메인 간 요청을 처리하는 방법을 자세히 설명합니다. 이 글이 Laravel에서 CORS를 구현하는 데 도움이 되기를 바라며 참조할 수 있는 충분한 코드 예제를 제공합니다. 🎜위 내용은 미들웨어를 사용하여 Laravel에서 CORS(교차 원본 리소스 공유)를 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!