ThinkPHP6 크로스 도메인 요청 처리: 프런트엔드와 백엔드 분리 문제 해결
ThinkPHP6 도메인 간 요청 처리: 프런트엔드와 백엔드 분리 문제 해결
인터넷 애플리케이션의 지속적인 개발과 함께 프런트엔드와 백엔드 분리의 개발 모델이 점점 더 많아지고 있습니다. 흔한. ThinkPHP6 프레임워크를 사용하여 프런트엔드와 백엔드를 분리하는 애플리케이션을 개발할 때 도메인 간 요청이 일반적인 문제가 되었습니다. 이 기사에서는 ThinkPHP6에서 도메인 간 요청을 처리하는 방법을 소개하고 해당 코드 예제를 제공합니다.
1. 교차 도메인 요청이란 무엇입니까?
교차 도메인 요청은 프런트 엔드 코드가 Ajax 및 기타 방법을 통해 다른 도메인 이름이나 포트의 백엔드에 요청을 보내는 웹 애플리케이션을 의미합니다. 브라우저의 동일 출처 정책 제한으로 인해 요청된 URL이 현재 페이지의 도메인 이름, 프로토콜 또는 포트와 다른 경우 브라우저는 요청을 차단합니다.
2. 도메인 간 요청을 해결하는 방법
- HTTP 응답 헤더 설정
ThinkPHP6에서는 컨트롤러에서 응답 헤더를 설정하여 도메인 간 요청 문제를 해결할 수 있습니다. 크로스 도메인 요청을 지원해야 하는 컨트롤러 메소드에서는 다음 코드를 사용하여 응답 헤더를 설정할 수 있습니다.
<?php namespace appcontroller; use thinkacadeRequest; class Index { public function index() { $allowOrigin = Request::header('origin'); $allowHeaders = 'X-Requested-With, Content-Type, Authorization'; $allowMethods = 'GET, POST, PUT, DELETE, PATCH, OPTIONS'; header("Access-Control-Allow-Origin: ".$allowOrigin); header("Access-Control-Allow-Headers: ".$allowHeaders); header("Access-Control-Allow-Methods: ".$allowMethods); } }
위 코드에서 요청의 원본 헤더 정보를 가져와서 Access-Control로 설정합니다. -Allow-Origin 응답 헤드. 동시에 다른 사용자 지정 요청 헤더 및 요청 방법을 지원하도록 Access-Control-Allow-Headers 및 Access-Control-Allow-Methods 헤더를 설정할 수도 있습니다.
- 미들웨어를 사용하여 도메인 간 요청 처리
컨트롤러에서 응답 헤더를 설정하는 것 외에도 미들웨어를 사용하여 도메인 간 요청을 처리할 수도 있습니다. ThinkPHP6에서는 크로스 도메인 미들웨어를 생성하는 것이 매우 간단합니다. app/middleware 디렉터리에 Cors.php 파일을 생성하고 해당 코드를 작성하기만 하면 됩니다.
<?php namespace appmiddleware; class Cors { public function handle($request, Closure $next) { $allowOrigin = $request->header('origin'); $allowHeaders = 'X-Requested-With, Content-Type, Authorization'; $allowMethods = 'GET, POST, PUT, DELETE, PATCH, OPTIONS'; header("Access-Control-Allow-Origin: ".$allowOrigin); header("Access-Control-Allow-Headers: ".$allowHeaders); header("Access-Control-Allow-Methods: ".$allowMethods); return $next($request); } }
다음으로, app/middleware.php 파일에 미들웨어를 등록하세요:
<?php // 其他中间件... ppmiddlewareCors::class,
등록이 완료되면 미들웨어는 모든 요청 전에 처리되며 자동으로 응답 헤더를 추가하여 교차 도메인 요청을 지원합니다.
3. 교차 도메인 요청 처리 확인
교차 도메인 요청 처리가 적용되었는지 확인하려면 브라우저의 개발자 도구를 사용하여 요청의 응답 헤더를 볼 수 있습니다. 브라우저의 개발자 도구를 열고(일반적으로 F12 키를 누름) 네트워크 탭을 선택한 후 테스트 요청을 하세요. 응답 헤더에서 Access-Control-Allow-Origin, Access-Control-Allow-Headers 및 Access-Control-Allow-Methods와 같은 헤더 정보를 볼 수 있어야 합니다.
4. 요약
이 글에서는 ThinkPHP6에서 도메인 간 요청을 처리하는 방법을 소개합니다. HTTP 응답 헤더를 설정하거나 미들웨어를 사용하면 프런트엔드 및 백엔드 분리 애플리케이션에서 도메인 간 요청 문제를 쉽게 해결할 수 있습니다. 실제 개발에서는 필요에 따라 적절한 방법을 선택하고 특정 시나리오에 따라 해당 구성과 유연한 처리를 수행합니다.
ThinkPHP6 프레임워크를 사용하여 프런트엔드 및 백엔드 분리 애플리케이션을 개발할 때 이 기사가 도메인 간 요청을 처리하는 데 도움이 되기를 바랍니다. 질문이나 제안사항이 있으시면 토론을 위해 메시지를 남겨주세요.
위 내용은 ThinkPHP6 크로스 도메인 요청 처리: 프런트엔드와 백엔드 분리 문제 해결의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

SublimeText3 영어 버전
권장 사항: Win 버전, 코드 프롬프트 지원!

SublimeText3 Linux 새 버전
SublimeText3 Linux 최신 버전

WebStorm Mac 버전
유용한 JavaScript 개발 도구

mPDF
mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.
