JavaScript

[JSON] JS - JSON - JSONP (= script 이용한 서버연동)

목차
  1. JSONP 소개
  2. JSONP 예제1 - 페이지 로드 시 자동출력
  3. JSONP 예제2 - 버튼 클릭했을 때만 출력
  4. JSONP 예제3 - 버튼 클릭했을 때만 출력 (서버DB 연결)
  5. [참고] 배열키 결정 방법

 

JSONP 소개 

 

도메인 간 생기는 문제 걱정 없이 JSON 데이터 전송하는 방법.

 


 

1.

데이터 전송에 <script> 태그 사용. (※ XMLHttpRequest 객체 사용 X)
(예)  <script src="a.php"></script>

2.
JSONP (=JSON + Padding) = 패딩 있는 JSON

 

3.

다른 도메인의 파일을 요청하면 도메인 간 정책으로 인해 문제가 발생 가능.

그러나, 다른 도메인에서 외부 script  요청하는 데는 문제 발생 안 함.

이 점에 착안해,
JSONP는 XMLHttpRequest 객체 대신 script 태그를 사용해서 파일 요청.

 

 

JSONP 예제1 - 페이지 로드 시 자동출력

b.php (브라우저 출력)

 

<p id="demo"></p>


<script>

function myFunc(myObj) {

  document.getElementById("demo").innerHTML = myObj.site;

}

</script>


<script src="a.php"></script>

 

PS. 이 방법은 페이지 로드 중 함수를 실행해서 바람직 안 함.


a.php (서버 처리)

 

<?php

$myJSON = '{ "site":"홈짱닷컴", "domain":"Homzzang.com", "open":2012 }';

echo "myFunc(".$myJSON.");";

?>



JSONP 예제2 - 버튼 클릭했을 때만 출력

 

b.php (브라우저 출력)

 

<button onclick="clickButton()">클릭</button>


<p id="demo"></p>


<script>

function clickButton() {

  var s = document.createElement("script");

  s.src = "a.php";

  document.body.appendChild(s);

}


function myFunc(myObj) {

  document.getElementById("demo").innerHTML = myObj.site;

}

</script>

 

PS. 이 방법은 필요할 때 함수를 호출해 실행하므로 바람직.


a.php (서버 처리)

 

앞 예제와 동일. 

 


JSONP 예제3 - 버튼 클릭했을 때만 출력 (서버DB 연결)

b.php (브라우저측)

 

<button onclick="btn()">클릭</button>


<p id="demo"></p>


<script>

function btn() {

  var obj, s

  obj = { limit: 10 };

  s = document.createElement("script");

  s.src = "a.php?x=" + JSON.stringify(obj); // JS 객체를 JSON 객체로 변환

  document.body.appendChild(s);

}


function myFunc(myObj) {

  var x, txt = "";

  for (x in myObj) {

    txt += myObj[x].mb_name + "<br>";

  }

  document.getElementById("demo").innerHTML = txt;

}

</script>

 


a.php (서버측)

 

<?php

header("Content-Type: application/json; charset=UTF-8");

 

$obj = json_decode($_GET["x"], false);
 // JSON 요청을 PHP 객체로 변환

$conn = new mysqli("localhost", "root", "autoset", "mw7"); 
// 서버 DB 연결 (호스트, ID, PW, DB명)

 

$result = $conn->query("SELECT mb_name FROM g5_member LIMIT ".$obj->limit);

$outp = array();

$outp = $result->fetch_all(MYSQLI_ASSOC); 
// 필드명을 배열키로 사용

echo "myFunc(".json_encode($outp).")"; 
// PHP 배열을 JSON으로 변환

?>

 

[주의] 워삼스쿨 경우, $limit 변수로 되어 있는데 그냥 limit로 적어야 됨.

  

[참고] 배열키 결정 방법

 

MYSQLI_ASSOC : 필드명을 배열키로 사용

MYSQLI_NUM : 숫자를 배열키로 사용

MYSQLI_BOTH: 필드명과 숫자 모두 배열키로 사용

 


방문 감사합니다. (즐겨찾기 등록: Ctrl + D)

분류 제목
DOM JS - CSS - 스타일변경
DOM JS - Animation - 애니메이션 (= 동적효과 = 움직임효과)
DOM JS - Events - 이벤트 2
DOM JS - addEventListener() 메서드 ★★★★★ - 이벤트 걸기 (= addEventListen…
DOM JS - Navigation - 노드탐색 (= 요소탐색) ※ 텍스트노드복사
DOM JS - Node - 노드추가, 노드삭제, 노드변경 (= 노드생성, 노드제거, 노드교체)
DOM JS - Collection - HTML요소집합 (= HTML요소묶음)
BOM JS - Window BOM - 윈도우 브라우저객체모델 (BOM: Browser Object Model)
BOM JS - Window Screen 객체 - 화면객체 (= 스크린객체 = screen객체)
BOM JS - Window Location 객체 - 위치객체 (= 로케이션객체 = Location객체) ※ loc…
BOM JS - Window History 객체 - 이력객체 (= 히스토리객체 = History객체 = 뒤로가기 +…
BOM JS - Window Navigator 객체 - 브라우저객체 (= 네이게이터객체 = Navigator객체 =…
BOM JS - Popup Boxes - 팝업상자 (= 팝업박스 = Alert Box + Confirm box + …
BOM JS - Timing Events ★ - 시간간격 코드실행 (= 타이밍 이벤트 = 시간이벤트 = 일정시간별 …
BOM JS - Cookie (쿠키) 사용법 ★★★ - 쿠키 (설정・생성) / 쿠키 (읽기・얻기・가져오기) / 쿠…
5/89
목록
  • 채팅방
  • 필독
1. 채팅창 헤드에서 접속자 확인 2. 닉네임 클릭해 1:1 채팅 가능 3. 닉네임 클릭해 귓속말 가능 4. 닉네임 클릭해 호출하기 가능 5. 우하단 클릭해 환경 설정 가능 6. 의뢰글 작성 후 의뢰 상담 가능 7. 질문글 작성 후 질문 상담 가능 8. 채팅방에 개인정보 입력 금지 9. 채팅방에 광고 욕설 비방 금지
 홈  PC버전 로그인 일본어
웹디자인언어
서버관리언어
고급코딩언어
그누보드 3
제작의뢰
Q&A
커뮤니티
웹유틸
회원센터
홈짱 PC버전 로그인