>  기사  >  웹 프론트엔드  >  실행 전 옵션 요청은 어떻게 WCF 서비스에 대한 도메인 간 HTTP 액세스를 활성화합니까?

실행 전 옵션 요청은 어떻게 WCF 서비스에 대한 도메인 간 HTTP 액세스를 활성화합니까?

Linda Hamilton
Linda Hamilton원래의
2024-10-18 21:57:30320검색

How Do Preflight Options Requests Enable Cross-Domain HTTP Access to WCF Services?

실행 전 옵션 요청을 사용하여 도메인 간 WCF 서비스에 액세스

WCF 서비스에 도메인 간 HTTP 요청을 시도하는 경우 CORS 제한 사항을 고려하는 것이 중요합니다. 이 문서에서는 이러한 장애물을 극복하기 위해 OPTIONS를 사용하여 HTTP 요청을 프리플라이트하는 방법을 살펴봅니다.

프리플라이트 프로세스

실제 요청을 보내기 전에 브라우저는 OPTIONS 요청을 사용하여 요청을 프리플라이트하여 서버가 요청을 허용합니다. 이 단계에는 두 개의 특수 요청 헤더 전송이 포함됩니다.

  • Access-Control-Request-Method: 실제 요청의 HTTP 메소드를 지정합니다(예: GET, POST)
  • Access-Control -요청 헤더: 실제 요청에 포함될 모든 사용자 정의 헤더를 나열합니다

서버측 응답

이러한 실행 전 요청을 수용하려면 서버가 적절한 헤더로 응답해야 합니다.

  • Access-Control-Allow-Origin: 리소스에 액세스하도록 허용된 출처를 지정합니다.
  • Access-Control-Allow-Methods: 리소스에 허용되는 HTTP 메서드를 나열합니다.
  • Access-Control-Allow-Headers: 실제 요청에서 허용되는 사용자 정의 헤더를 열거합니다

jQuery.getJSON을 사용한 프리플라이트

GET 요청에 jQuery.getJSON을 사용하려면 다음이 필요합니다. OPTIONS 요청으로 프리플라이트합니다. 이는 다음과 같이 구현할 수 있습니다.

<code class="javascript">$.ajax({
  url: "http://your.wcf.endpoint",
  type: "OPTIONS",
  success: function(data) {
    console.log("Preflight successful:", data);
  }
});

$.getJSON("http://your.wcf.endpoint", function(data) {
  console.log("Actual GET request:", data);
});</code>

응답 헤더 예시

다음 헤더가 포함된 수신 전 실행 요청을 고려하세요.

Origin: http://yourdomain.com
Access-Control-Request-Method: POST
Access-Control-Request-Headers: X-Custom-Header

서버는 다음으로 응답해야 합니다.

Access-Control-Allow-Origin: http://yourdomain.com
Access-Control-Allow-Methods: GET, POST
Access-Control-Allow-Headers: X-Custom-Header

Access-Control-Request-Headers는 Access-Control-Allow-Headers 응답에 반영되어야 하며 '*' 와일드카드는 허용되지 않습니다.

위 내용은 실행 전 옵션 요청은 어떻게 WCF 서비스에 대한 도메인 간 HTTP 액세스를 활성화합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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