>웹 프론트엔드 >JS 튜토리얼 >JSONP는 jQuery에서 도메인 간 AJAX 문제를 어떻게 해결할 수 있습니까?

JSONP는 jQuery에서 도메인 간 AJAX 문제를 어떻게 해결할 수 있습니까?

Susan Sarandon
Susan Sarandon원래의
2024-12-18 09:49:10197검색

How Can JSONP Solve Cross-Domain AJAX Issues in jQuery?

jQuery를 사용한 크로스 도메인 AJAX

jQuery의 AJAX 기능은 동적 웹 개발에 필수적인 도구입니다. 그러나 서로 다른 도메인에서 AJAX 요청을 수행할 때 CORS(교차 원본 리소스 공유) 문제가 발생할 수 있습니다.

test.php와 testserver.php가 별도의 서버에 상주할 때 이러한 문제가 발생하여 " 오류' 경고가 트리거됩니다. 이는 브라우저 보안 조치가 기본적으로 다른 출처의 AJAX 요청을 제한하기 때문입니다.

해결책: JSONP

CORS를 극복하기 위해 JSONP(JSON with Padding)를 사용할 수 있습니다. JSONP는 CORS를 피하면서 원격 서버에서 스크립트를 동적으로 로드하여 다른 접근 방식을 활용합니다. 제한 사항.

구현

jQuery:

$.ajax({
  url: "testserver.php",
  dataType: 'jsonp', // Specify JSONP data type
  success:function(json){
    // Process JSON data
    alert("Success");
  },
  error:function(){
    alert("Error");
  }      
});

PHP:

<?php
$arr = array("element1", "element2", array("element31", "element32"));
$arr['name'] = "response";
echo $_GET['callback']. "(".json_encode($arr).");";
?>

PHP의 echo 문은 다음과 같이 설계되었습니다. 적절한 따옴표를 포함하여 jQuery가 제공하는 콜백 함수 내에서 JSON 데이터를 래핑합니다.

또는 jQuery의 $.getJSON()을 "callback=?"을 추가하는 것과 함께 약식 메서드로 사용할 수 있습니다. URL에 대한 GET 매개변수로. jQuery는 이 매개변수를 기반으로 적절한 콜백 함수를 자동으로 생성합니다.

위 내용은 JSONP는 jQuery에서 도메인 간 AJAX 문제를 어떻게 해결할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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