//json 인코딩 함수
function json_encode2($data) {
switch (gettype($data)) {
case 'boolean':
return $data?'true':'false';
case 'integer':
case 'double':
return $data;
case 'string':
return '"'.strtr($data, array('\\'=>'\\\\','"'=>'\\"')).'"';
case 'array':
$rel = false; // relative array?
$key = array_keys($data);
foreach ($key as $v) {
if (!is_int($v)) {
$rel = true;
break;
}
}
$arr = array();
foreach ($data as $k=>$v) {
$arr[] = ($rel?'"'.strtr($k, array('\\'=>'\\\\','"'=>'\\"')).'":':'').json_encode2($v);
}
return $rel?'{'.join(',', $arr).'}':'['.join(',', $arr).']';
default:
return '""';
}
}
header('Access-Control-Allow-Origin: *');
header('Access-Control-Allow-Methods: POST, GET, OPTIONS');
header('Access-Control-Max-Age: 1000');
if(array_key_exists('HTTP_ACCESS_CONTROL_REQUEST_HEADERS', $_SERVER)) {
header('Access-Control-Allow-Headers: '
. $_SERVER['HTTP_ACCESS_CONTROL_REQUEST_HEADERS']);
} else {
header('Access-Control-Allow-Headers: *');
}
if("OPTIONS" == $_SERVER['REQUEST_METHOD']) {
exit(0);
}
//데이터 예시
$result = 쿼리
while($row = mysql_fetch_array($result)){
$result_array[] = $row;
}
header('Cache-Control: no-cache, must-revalidate');
header('Expires: Mon, 26 Jul 1997 05:00:00 GMT');
header('Content-type: application/json');
$result_array=json_encode2($result_array);
print $result_array;
제가 관리하는 사이트 서버가 오래되어서 php 4버전이다 보니
json 함수가 사용이 안되어서 찾은 소스 입니다.
참고 문자 캐릭터형을 정확하게 사용하셔야 합니다.
댓글 2개
게시판 목록
팁게시판
질문은 상단의 QA에서 해주시기 바랍니다.
| 번호 | 제목 | 글쓴이 | 날짜 | 조회 |
|---|---|---|---|---|
| 5852 | 9년 전 | 635 | ||
| 5851 | 9년 전 | 564 | ||
| 5850 | 9년 전 | 411 | ||
| 5849 | 9년 전 | 310 | ||
| 5848 | 9년 전 | 312 | ||
| 5847 | 9년 전 | 306 | ||
| 5846 | 9년 전 | 292 | ||
| 5845 | 9년 전 | 312 | ||
| 5844 | 9년 전 | 342 | ||
| 5843 | 9년 전 | 432 | ||
| 5842 | 9년 전 | 325 | ||
| 5841 | 9년 전 | 1096 | ||
| 5840 |
|
9년 전 | 1218 | |
| 5839 | 9년 전 | 602 | ||
| 5838 | 9년 전 | 334 | ||
| 5837 | 9년 전 | 382 | ||
| 5836 | 9년 전 | 379 | ||
| 5835 | 9년 전 | 506 | ||
| 5834 | 9년 전 | 344 | ||
| 5833 | 9년 전 | 459 | ||
| 5832 | 9년 전 | 292 | ||
| 5831 | 9년 전 | 282 | ||
| 5830 | 10년 전 | 303 | ||
| 5829 | 10년 전 | 353 | ||
| 5828 | 10년 전 | 331 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기