//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에서 해주시기 바랍니다.
| 번호 | 제목 | 글쓴이 | 날짜 | 조회 |
|---|---|---|---|---|
| 4902 | 13년 전 | 3549 | ||
| 4901 |
후라보노보노
|
13년 전 | 2170 | |
| 4900 |
|
13년 전 | 4127 | |
| 4899 |
|
13년 전 | 3376 | |
| 4898 |
|
13년 전 | 4896 | |
| 4897 | 13년 전 | 2695 | ||
| 4896 | 13년 전 | 2163 | ||
| 4895 |
|
13년 전 | 2489 | |
| 4894 |
|
13년 전 | 2831 | |
| 4893 | 13년 전 | 1465 | ||
| 4892 | 13년 전 | 1893 | ||
| 4891 |
|
13년 전 | 1915 | |
| 4890 | 13년 전 | 6102 | ||
| 4889 |
|
13년 전 | 1559 | |
| 4888 |
프로프리랜서
|
13년 전 | 1390 | |
| 4887 | 13년 전 | 1774 | ||
| 4886 |
|
13년 전 | 2239 | |
| 4885 | 13년 전 | 1573 | ||
| 4884 | 13년 전 | 1906 | ||
| 4883 | 13년 전 | 3300 | ||
| 4882 | 13년 전 | 3579 | ||
| 4881 | 13년 전 | 1946 | ||
| 4880 | 13년 전 | 699 | ||
| 4879 | 13년 전 | 5862 | ||
| 4878 |
Giggle
|
13년 전 | 1702 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기