>백엔드 개발 >PHP 튜토리얼 >Laravel 개발에서 도메인 간 문제를 해결하는 방법

Laravel 개발에서 도메인 간 문제를 해결하는 방법

不言
不言원래의
2018-06-13 14:08:491726검색

최근 개발 과정에서 크로스 도메인 요구사항을 접하게 되었고 관련 정보를 검색하면서 관련 솔루션을 찾았습니다. 따라서 다음 글에서는 주로 샘플 코드를 통해 소개하는 라라벨 개발의 크로스 도메인 솔루션을 소개합니다. 매우 상세합니다. 필요한 친구들은 참고하면 됩니다.

머리말

우리 모두가 알고 있듯이 라라벨을 개발에 사용할 때, 특히 프론트엔드와 백엔드가 완전히 분리된 경우, 프론트엔드 프로젝트는 자체적으로 지정된 포트에서 실행되기 때문에 예를 들어 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(&#39;HTTP_ORIGIN&#39;) ? $request->server(&#39;HTTP_ORIGIN&#39;) : &#39;&#39;;
 $allow_origin = [
  &#39;http://localhost:8000&#39;,
 ];
 if (in_array($origin, $allow_origin)) {
  $response->header(&#39;Access-Control-Allow-Origin&#39;, $origin);
  $response->header(&#39;Access-Control-Allow-Headers&#39;, &#39;Origin, Content-Type, Cookie, X-CSRF-TOKEN, Accept, Authorization, X-XSRF-TOKEN&#39;);
  $response->header(&#39;Access-Control-Expose-Headers&#39;, &#39;Authorization, authenticated&#39;);
  $response->header(&#39;Access-Control-Allow-Methods&#39;, &#39;GET, POST, PATCH, PUT, OPTIONS&#39;);
  $response->header(&#39;Access-Control-Allow-Credentials&#39;, &#39;true&#39;);
 }
 return $response;
 }
}

$allow_origin 배열 변수는 도메인 목록을 허용하는 것입니다. 예 , 직접 수정할 수 있습니다.

3. 그런 다음 커널 파일에 미들웨어를 등록합니다.

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

AppHttpKernel 클래스의 $middleware 속성에 추가합니다. 여기에 등록된 미들웨어는 전역 미들웨어에 속합니다.
그러면 프런트 엔드 페이지에서 이미 도메인 간 요청을 보낼 수 있음을 알 수 있습니다.

서버가 도메인 간 요청을 허용하는지 여부를 먼저 브라우저에서 확인해야 하기 때문에 메서드가 옵션으로 설정된 요청이 하나 더 있는 것은 정상입니다.

위 내용은 이 글의 전체 내용입니다. 모든 분들의 학습에 도움이 되었으면 좋겠습니다. 더 많은 관련 내용은 PHP 중국어 홈페이지를 주목해주세요!

관련 권장 사항:

Laravel이 프런트 엔드 Ajax에서 데이터 분석을 수신하는 정보

PHP의 Laravel 프레임워크에서 비동기 프로세스를 실행하도록 감독자를 구현하는 방법

위 내용은 Laravel 개발에서 도메인 간 문제를 해결하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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