jsonp란 무엇인가요? 무슨 소용이 있나요? 이 글에서는 jsonp에 대해 소개하고 도움이 필요한 친구들이 참고할 수 있도록 하겠습니다.
더 이상 고민하지 말고 바로 본문으로 들어가겠습니다~
jsonp가 무엇인가요?
인터넷에서 jsonp의 정의를 찾을 수 있습니다. JSONP(JSON with Padding)는 주류 브라우저의 도메인 간 데이터 액세스 문제를 해결하는 데 사용할 수 있는 JSON의 "사용 모드"입니다. 동일 출처 정책으로 인해 일반적으로 다음 지역에 위치합니다. server1.example.com의 웹페이지는 server1.example.com 이외의 서버와 통신할 수 없으며, HTML 3f1c4e4b6b16bbbd69b2ee476dc4f83a 요소는 예외입니다. 3f1c4e4b6b16bbbd69b2ee476dc4f83a 요소의 공개 정책을 사용하면 웹페이지는 다른 소스에서 동적으로 생성된 스크립트를 가져올 수 있습니다. JSON 데이터이며, 이러한 사용 패턴을 JSONP라고 합니다. 사실 간단히 말해서 jsonp는 도메인 간 요청 문제를 해결하는 데 사용되는 경량 데이터 전송 형식입니다.
jsonp
ajax 요청은 동일 출처 정책의 영향을 받으며 도메인 간 요청을 허용하지 않는다는 원칙을 분석해 보겠습니다. 그러나 스크립트 태그의 src 속성에 있는 링크는 크로스 도메인 js에 액세스할 수 있습니다. 이 기능을 사용하면 서버가 더 이상 JSON 형식으로 데이터를 반환하지 않지만 src에서 호출되는 특정 함수를 호출하는 js 코드를 반환하므로 교차 도메인 기능이 구현됩니다.
jsonp의 예를 살펴보겠습니다.
<!DOCTYPE html> <html> <head> <title>GoJSONP</title> </head> <body> < script type="text/javascript"> function jsonhandle(data){ alert("age:" + data.age + "name:" + data.name); } </script> <script type="text/javascript" src="jquery-1.8.3.min.js"> </script> <script type="text/javascript"> $(document).ready(function(){ var url = "http://www.practice-zhao.com/student.php?id=1&callback=jsonhandle"; var obj = $('<script><\/script>'); obj.attr("src",url); $("body").append(obj); }); </script> </body> </html>
여기에 스크립트 태그가 동적으로 추가되고, src는 크로스 도메인 PHP 스크립트를 가리키며, 위의 js 함수 이름이 콜백 매개변수로 전달됩니다. PHP 코드 살펴보기 작성 방법:
<?php $data = array( 'age' => 20, 'name' => '张三', ); $callback = $_GET['callback']; echo $callback."(".json_encode($data).")"; return;
PHP 코드는 JS 문, 즉
이때 페이지에 접속하면 동적으로 스크립트 태그가 추가되고, src는 PHP 스크립트를 가리키며, 반환되는 JS 코드가 실행되고 프롬프트 상자가 성공적으로 나타납니다.
따라서 JSONP는 도메인 간 요청에 대한 액세스를 원격 JS 코드 실행으로 전환합니다. 서버는 더 이상 JSON 형식으로 데이터를 반환하지 않지만 JSON 데이터를 수신 매개변수로 사용하는 함수 실행 코드를 반환합니다.
이 글은 여기서 끝납니다. 더 많은 jsonp 관련 콘텐츠를 보려면 PHP 중국어 웹사이트를 팔로우하세요! ! !
위 내용은 jsonp란 무엇인가요? jsonp의 원리에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!