JSONP의 구현 원리
이번에는 JSONP의 구현 원리와 JSONP 사용 시 주의사항에 대해 알려드리겠습니다. 실제 사례를 살펴보겠습니다.
JSONP의 구현 원리
프런트엔드와 백엔드 분리에 종사하는 많은 사람들이 JSONP에 노출되는 경우가 많다고 생각합니다. 그러나 많은 초보자들은 JSONP 구현 방법과 구현 원리를 모릅니다. 자세히 소개하기 위한 글입니다. 관심있으신 분들은 꼭 들러보세요.
기본 원칙
기본 원칙은 설명하기 쉽습니다. HTML 페이지에는 img, script, link 등과 같이 도메인 간 제한이 적용되지 않는 태그가 있습니다. 필요한 데이터를 js 파일에 넣으면 브라우저의 동일 출처 제한을 극복할 수 있습니다.
스크립트 태그 만들기
저자는 "High Performance JavaScript"에서 동적 스크립트 요소에 대해 언급했습니다.
1. 요소가 페이지에 추가되면 파일 다운로드가 시작됩니다. 이 기술의 핵심은 다운로드가 시작될 때마다 파일 다운로드 및 실행이 페이지의 다른 프로세스를 차단하지 않는다는 것입니다.
2. 동적 스크립트 노드를 사용하여 파일을 다운로드할 때 반환된 코드는 일반적으로 즉시 실행됩니다(이전의 모든 동적 스크립트 노드가 실행을 완료할 때까지 기다리는 Firefox 및 Oprea 제외). 스크립트가 자체적으로 실행될 때 이 메커니즘은 정상적으로 작동합니다. .
Quote1은 JSONP 요청 시 메인 스레드가 차단되지 않도록 보장합니다. Quote 2는 로딩이 완료된 후 즉시 JSONP 코드가 실행될 때 오류가 발생하지 않도록 보장합니다.
콜백
서버는 일반적으로 GET 요청을 받은 후 콜백 매개변수가 있는지 확인합니다. 그렇다면 반환된 데이터 외부에 메서드 이름과 괄호를 추가해야 합니다. 예를 들어 다음과 같이 요청합니다.
http://www.a.com/getSomething?callback=jsonp0
그러면 서버는 다음 콘텐츠를 반환합니다:
jsonp0({code:200,data:{}})
분명히 이것은 동적으로 로드된 스크립트 태그에 포함된 내용이므로 자체 실행 코드이고 이 코드 중 단 하나의 함수(jsonp0)만 호출됩니다.
물론 실행이 있으면 먼저 생성해야 하고, 그렇지 않으면 오류가 보고됩니다. 호출하기 전에 이 생성 단계를 실행해야 합니다.
구체적인 구현은 다음과 같습니다:
function jsonp (url, successCallback, errorCallback, completeCallback) { // 声明对象,需要将函数声明至全局作用域 window.jsonp0 = function (data) { successCallback(data); if (completeCallback) completeCallback(); } // 创建script标签,并将url后加上callback参数 var script = document.createElement('script') , url = url + (url.indexOf('?') == -1 ? '?' : '&') + 'callback=jsonp0' ; script.src = url; document.head.parentNode.insertBefore(script, document.head); // 等到script加载完毕以后,就会自己执行 }
위의 내용은 기본적으로 jsonp 메소드의 핵심을 완성합니다. 이때 jsonp0은 우리가 선언한 함수입니다. 서버가 정상적으로 반환되면 jsonp0 함수가 실행되고 내부의 SuccessCallback 콜백도 실행됩니다.
개선해보세요
실제 상황에서는 일반적으로 동시에 많은 jsonp 요청이 호출됩니다.
그러면 jsonp0이 우리의 요구를 충족시킬 수 있는데 왜 jsonp1, jsonp2 등의 코드가 순차적으로 쌓이는 것을 자주 볼 수 있을까요?
이는 많은 요청이 비동기적으로 이루어질 수 있기 때문입니다. jsonp 메소드가 처음 실행되면 window.jsonp0은 함수 A입니다. 이때 js 파일이 로드됩니다. js가 로드되지 않으면 jsonp 메소드가 다시 호출됩니다. 기능 B. 그런 다음 두 개의 j가 로드된 후 두 번째 콜백이 실행됩니다.
따라서 콜백 이름에 구분을 두어야 하며, 축적은 그 요구를 충족시킬 수 있습니다.
코드 수정:
var jsonpCounter = 0; function jsonp (url, successCallback, errorCallback, completeCallback) { var jsId = 'jsonp' + jsonpCounter++; // 声明对象,需要将函数声明至全局作用域 window[jsId] = function (data) { successCallback(data); if (completeCallback) completeCallback(); clean(); } // 创建script标签,并将url后加上callback参数 var script = document.createElement('script') , url = url + (url.indexOf('?') == -1 ? '?' : '&') + 'callback=' + jsId ; script.src = url; document.head.parentNode.insertBefore(script, document.head); // 等到script加载完毕以后,就会自己执行 //在执行完我们这个方法以后,会有很多script标签出现在head之前,我们需要手动的删除掉他们。 function clean () { script.parentNode.removeChild(script); window[jsId] = function(){}; } }
누적 및 정리를 추가한 후 처리해야 할 또 다른 중요한 사항이 있는데, 바로 오류 콜백입니다. 일반적으로 jsonp를 요청할 때 시간 초과를 설정합니다. 이 시간이 초과되면 시간 초과 예외가 발생합니다.
다음과 같이 구현되었습니다:
var jsonpCounter = 0; function jsonp (url, successCallback, errorCallback, completeCallback, timeout) { // 略去上面写过的代码 var timeout = timeout || 10000 , timer ; if (timeout) { timer = setTimeout(function () { if (errorCallback) { errorCallback(new Error('timeout')); } clean(); }, timeout) } function clean () { script.parentNode.removeChild(script); window[jsId] = function(){}; if (timer) clearTimeout(timer); } }
이러한 방식으로 jsonp의 모든 기능은 기본적으로 완성되며, 나머지 기능은 완전한 jsonp 메서드로 간주되기 위해 일부 호환 가능한 수정이 필요할 수 있습니다.
REFER
이 기사의 사례를 읽은 후 방법을 마스터했다고 생각합니다. 더 흥미로운 정보를 보려면 PHP 중국어 웹사이트의 다른 관련 기사를 주목하세요!
추천 도서:
vue-router 구성 요소 간에 매개 변수를 전달하는 방법
Vue.js 모바일 구성 요소 라이브러리를 사용하는 방법
위 내용은 JSONP의 구현 원리의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











Huawei 휴대폰에서 이중 WeChat 로그인을 구현하는 방법은 무엇입니까? 소셜 미디어의 등장으로 WeChat은 사람들의 일상 생활에 없어서는 안될 커뮤니케이션 도구 중 하나가 되었습니다. 그러나 많은 사람들이 동일한 휴대폰에서 동시에 여러 WeChat 계정에 로그인하는 문제에 직면할 수 있습니다. Huawei 휴대폰 사용자의 경우 듀얼 WeChat 로그인을 달성하는 것은 어렵지 않습니다. 이 기사에서는 Huawei 휴대폰에서 듀얼 WeChat 로그인을 달성하는 방법을 소개합니다. 우선, 화웨이 휴대폰과 함께 제공되는 EMUI 시스템은 듀얼 애플리케이션 열기라는 매우 편리한 기능을 제공합니다. 앱 듀얼 오픈 기능을 통해 사용자는 동시에

프로그래밍 언어 PHP는 다양한 프로그래밍 논리와 알고리즘을 지원할 수 있는 강력한 웹 개발 도구입니다. 그중 피보나치 수열을 구현하는 것은 일반적이고 고전적인 프로그래밍 문제입니다. 이 기사에서는 PHP 프로그래밍 언어를 사용하여 피보나치 수열을 구현하는 방법을 소개하고 구체적인 코드 예제를 첨부합니다. 피보나치 수열은 다음과 같이 정의되는 수학적 수열입니다. 수열의 첫 번째와 두 번째 요소는 1이고 세 번째 요소부터 시작하여 각 요소의 값은 이전 두 요소의 합과 같습니다. 시퀀스의 처음 몇 가지 요소

Huawei 휴대폰에서 WeChat 복제 기능을 구현하는 방법 소셜 소프트웨어의 인기와 개인 정보 보호 및 보안에 대한 사람들의 강조가 높아지면서 WeChat 복제 기능이 점차 주목을 받고 있습니다. WeChat 복제 기능을 사용하면 사용자가 동일한 휴대폰에서 여러 WeChat 계정에 동시에 로그인할 수 있으므로 관리 및 사용이 더 쉬워집니다. Huawei 휴대폰에서 WeChat 복제 기능을 구현하는 것은 어렵지 않습니다. 다음 단계만 따르면 됩니다. 1단계: 휴대폰 시스템 버전과 WeChat 버전이 요구 사항을 충족하는지 확인하십시오. 먼저 Huawei 휴대폰 시스템 버전과 WeChat 앱이 최신 버전으로 업데이트되었는지 확인하세요.

Golang에서 정확한 나눗셈 작업을 구현하는 것은 특히 재무 계산과 관련된 시나리오 또는 고정밀 계산이 필요한 기타 시나리오에서 일반적인 요구 사항입니다. Golang에 내장된 나눗셈 연산자 "/"는 부동 소수점 수에 대해 계산되며 때로는 정밀도가 손실되는 문제가 있습니다. 이 문제를 해결하기 위해 타사 라이브러리나 사용자 정의 기능을 사용하여 정확한 분할 작업을 구현할 수 있습니다. 일반적인 접근 방식은 분수 표현을 제공하고 정확한 나눗셈 연산을 구현하는 데 사용할 수 있는 math/big 패키지의 Rat 유형을 사용하는 것입니다.

오늘날의 소프트웨어 개발 분야에서 효율적이고 간결하며 동시성이 뛰어난 프로그래밍 언어인 Golang(Go 언어)은 점점 더 개발자들의 선호를 받고 있습니다. 풍부한 표준 라이브러리와 효율적인 동시성 기능으로 인해 게임 개발 분야에서 주목받는 선택이 되었습니다. 이 기사에서는 게임 개발에 Golang을 사용하는 방법을 살펴보고 특정 코드 예제를 통해 Golang의 강력한 가능성을 보여줍니다. 1. 게임 개발에서 Golang의 장점 Golang은 정적인 유형의 언어로서 대규모 게임 시스템을 구축하는 데 사용됩니다.

PHP 게임 요구사항 구현 가이드 인터넷의 대중화와 발전으로 인해 웹 게임 시장이 점점 더 대중화되고 있습니다. 많은 개발자는 PHP 언어를 사용하여 자신만의 웹 게임을 개발하기를 원하며 게임 요구 사항을 구현하는 것이 핵심 단계입니다. 이 문서에서는 PHP 언어를 사용하여 일반적인 게임 요구 사항을 구현하는 방법을 소개하고 특정 코드 예제를 제공합니다. 1. 게임 캐릭터 만들기 웹게임에서 게임 캐릭터는 매우 중요한 요소입니다. 이름, 레벨, 경험치 등 게임 캐릭터의 속성을 정의하고, 이를 운용할 수 있는 방법을 제공해야 합니다.

실시간 프로그래밍 지침을 제공할 수 없어서 정말 죄송합니다. 하지만 PHP를 사용하여 SaaS를 구현하는 방법을 더 잘 이해할 수 있도록 코드 예제를 제공할 수 있습니다. 다음은 "PHP를 사용하여 SaaS 구현: 종합 분석"이라는 제목의 1,500자 이내의 기사입니다. 오늘날의 정보화 시대에 SaaS(Software as a Service)는 기업과 개인이 소프트웨어에 액세스하는 보다 유연하고 편리한 방법을 제공하는 주류가 되었습니다. SaaS를 사용하면 사용자가 온프레미스에 있을 필요가 없습니다.

제목: Golang을 이용한 데이터 내보내기 기능에 대한 자세한 설명 정보화가 진행됨에 따라 많은 기업과 조직에서는 데이터 분석, 보고서 생성 및 기타 목적을 위해 데이터베이스에 저장된 데이터를 다른 형식으로 내보내야 합니다. 이 기사에서는 Golang 프로그래밍 언어를 사용하여 데이터베이스 연결, 데이터 쿼리 및 데이터를 파일로 내보내기 위한 세부 단계를 포함하여 데이터 내보내기 기능을 구현하는 방법을 소개하고 구체적인 코드 예제를 제공합니다. 먼저 데이터베이스에 연결하려면 da와 같은 Golang에서 제공하는 데이터베이스 드라이버를 사용해야 합니다.
