laravel로 개발할 때, 특히 프론트엔드와 백엔드가 완전히 분리된 경우, 프론트엔드 프로젝트는 localhost와 같은 자체 머신(다른 사람 머신일 수도 있음)의 지정된 포트에서 실행되기 때문입니다. 8000이고 laravel 프로그램은 다른 포트에서 실행되므로 크로스 도메인이며, 브라우저의 동일 출처 정책으로 인해 크로스 도메인 요청은 불법입니다. 실제로 이 문제는 해결하기 쉽습니다. 미들웨어만 추가하면 됩니다.
1. 새 미들웨어 생성
php artisan make:middleware EnableCrossRequestMiddleware
2. 미들웨어 내용 작성
<?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:8000', ]; 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 배열 변수는 허용하는 크로스 도메인 목록이며 직접 수정할 수 있습니다.
3. 그런 다음 커널 파일에 미들웨어를 등록합니다
protected $middleware = [ // more App\Http\Middleware\EnableCrossRequestMiddleware::class, ];
AppHttpKernel 클래스의 $middleware 속성에 추가합니다. 여기에 등록된 미들웨어는 전역 미들웨어에 속합니다.
그러면 프런트 엔드 페이지에서 이미 도메인 간 요청을 보낼 수 있다는 것을 알게 될 것입니다.
서버가 도메인 간 요청을 허용하는지 여부를 먼저 브라우저에서 확인해야 하기 때문에 메서드가 옵션으로 설정된 요청이 하나 더 있는 것은 정상입니다.
더 많은 Laravel 관련 기술 기사를 보려면 Laravel Framework Getting Started Tutorial 칼럼을 방문하여 알아보세요!
위 내용은 laravel 크로스 도메인 솔루션의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!