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

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

Mary-Kate Olsen
풀어 주다: 2024-12-30 09:32:14
원래의
309명이 탐색했습니다.

How Can JSONP Solve jQuery's Cross-Domain AJAX Problems?

jQuery AJAX 도메인 간 딜레마: JSONP로 CORS 우회

다른 도메인에서 데이터와 상호 작용하면 원본 간 리소스 공유로 인해 문제가 발생합니다. (CORS) 제한 사항. localhost의 test.php 및 원격 서버의 testserver.php와 같이 한 도메인에서 다른 도메인으로 AJAX 요청을 수행하려고 하면 브라우저는 이러한 제한을 적용하여 "오류" 경고를 표시합니다.

이를 극복하려면 장애물이 발생하면 JSONP(JSON with Padding)가 실행 가능한 해결 방법으로 나타납니다. 스크립트 요소의 유연성을 활용하여 도메인 전체에서 데이터를 검색합니다.

jQuery 수정:
dataType 매개변수를 'jsonp'로 변경하여 JSONP를 활용하도록 test.php를 수정합니다.

PHP 수정:
testserver.php를 에코로 조정 jQuery에서 제공하는 콜백이 포함된 JSONP 응답.

구현:

jQuery(test.php):

$.ajax({
    url: "testserver.php",
    dataType: 'jsonp', // Notice! JSONP <-- P (lowercase)
    success: function(json){
        // do stuff with json (in this case an array)
        alert("Success");
    },
    error: function(){
        alert("Error");
    }       
});
로그인 후 복사

PHP (testserver.php):

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

$.getJSON()을 사용하는 단순화된 방법:
또는 $.getJSON() 단축 방법을 사용합니다. '콜백=?'을 추가합니다. GET 매개변수로 URL에 추가합니다.

$.getJSON("testserver.php", function(json){
    // do stuff with json (in this case an array)
    alert("Success");
});
로그인 후 복사

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

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿