CORS(교차 출처 리소스 공유)에서 웹 페이지는 일반적으로 다른 도메인, 포트, 또는 프로토콜. 그러나 기본적으로 브라우저는 보안 문제로 인해 이러한 요청을 제한합니다.
주어진 시나리오에서 사용자는 CORS를 사용하여 www.siteone.com에서 www.sitetwo.com으로 POST 요청을 시도하고 있습니다. 발생한 오류는 요청 헤더와 응답 헤더가 일치하지 않음을 나타냅니다.
CORS를 올바르게 구성하려면 신중하게 처리하는 것이 중요합니다. 다음 PHP 함수는 보다 포괄적인 접근 방식을 제공합니다.
<code class="php">// Allow from any origin if (isset($_SERVER['HTTP_ORIGIN'])) { header("Access-Control-Allow-Origin: {$_SERVER['HTTP_ORIGIN']}"); header('Access-Control-Allow-Credentials: true'); header('Access-Control-Max-Age: 86400'); // cache for 1 day } // Access-Control headers are received during OPTIONS requests if ($_SERVER['REQUEST_METHOD'] == 'OPTIONS') { if (isset($_SERVER['HTTP_ACCESS_CONTROL_REQUEST_METHOD'])) header("Access-Control-Allow-Methods: GET, POST, OPTIONS"); if (isset($_SERVER['HTTP_ACCESS_CONTROL_REQUEST_HEADERS'])) header("Access-Control-Allow-Headers: {$_SERVER['HTTP_ACCESS_CONTROL_REQUEST_HEADERS']}"); exit(0); } echo "You have CORS!";</code>
원본 코드를 이 향상된 함수로 대체하여 사용자는 CORS 문제를 성공적으로 해결했습니다. 이 접근 방식을 사용하면 필요한 모든 헤더가 적절하게 설정되어 교차 출처 요청이 의도한 대로 작동할 수 있습니다.
위 내용은 내 PHP 애플리케이션에서 CORS가 작동하지 않는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!