일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
- html
- git
- Lombok
- redis
- NoSQL
- 데이터통신
- r
- mongodb
- spring
- libuv
- cache
- nodejs
- mybatis
- VCS
- network
- Linux
- effective
- Java
- 네트워크
- socket
- Static
- AWS
- Elk
- javascript
- HTTP
- reactor
- reactive
- Heap
- github
- ajax
- Today
- Total
빨간색코딩
JSONP 본문
참조문서 : https://blog.seotory.com/post/2016/04/understand-jsonp
JSONP는 json with padding의 약자이다. <script /> 태그는 SOP 정책에 속하지 않는다는 점을 이용해, 서로 다른 도메인간의 javascript 호출을 위하여 jsonp가 사용되었다.
1. 원리
- API서버에 데이터를 요청할 페이지에서 서버의 데이터를 받아 처리할 콜백 함수를 준비한다. 그 후에 script 태그를 생성하고 API서버에 request한다.
- 데이터 요청을 받은 서버에서는 콜백 함수를 실행하는 스크립트를 출력한다. 이 때 callback 함수의 인자에는 요청받은 데이터(기존 JSON)가 들어간다.
즉, 기존에 서버에서 {"key1" : "value1", "key2" : "value2"}
이런 형식으로 json을 반환해주었다면, JSONP에서는 callback({"key1" : "value1", "key2" : "value2"});
이런식으로 반환해준다.
AJAX랑 비교사진이다. JSONP는 서버측에서 콜백함수를 실행하는 코드를 반환하는 점만 다르다.
2. 구현
jQuery v.1.2 이상부터 jsonp 형태가 지원된다. $.ajax 옵션에서 dataType: "jsonp"
를 설정해야한다. type은 GET으로 해야한다.
AJAX api의 JSONP 관련 속성
- dataType : 'jsonp' 지정
- jsonp : 일반적으로 client에서 지정한 'callback' argument (http:host:port/jsonp_uri?callback=jquery function)를 서버에서는 호출할 function으로 지정한다. 하지만 arguemnt명이 callback이 아니라면 jsonp 속성으로 지정하면 변경됨.
- jsonpCallback : jsonp 결과값이 전달될 function을 지정할 수 있음. 기본적으로는 jquery에서 알아서 지정한다.
3. CORS vs JSONP
참조문서 : https://stackoverflow.com/questions/12296910/so-jsonp-or-cors
해당 참조문서는 12년도 글이라서 최신 브라우저일 경우 CORS를, 아니라면 JSONP를 사용하라고 권장하고 있지만, 이제는 대부분 CORS를 지원한다. CORS는 크로스도메인을 해결하는 웹 표준이고, 보안상 권장되고 있다. 허용 도메인에 정규표현식으로도 표현할 수 있다. 또한 JSONP가 GET밖에 지원안하는 것과 대비되게 다양한 메소드를 허용하고 있다.
또한 JSONP는 http에서 https는 호출가능하지만, https에서 http는 호출이 불가능하다. This request has been blocked; the content must be served over HTTPS.
'Web' 카테고리의 다른 글
Chrome Devtool (CPU프로파일링, 힙덤프) (0) | 2017.08.04 |
---|---|
CORS vs JSONP (0) | 2017.07.26 |
크로스도메인 이슈 (SOP, CORS) (0) | 2017.07.25 |
V8 javascript 엔진 (Hidden Class, 인라인캐싱, 메모리구조, 호출스택, heap, GC) (0) | 2017.07.21 |
JQuery 기초 (JQuery 객체, 조작) (0) | 2017.07.21 |