COMING SOON 🚀

k

서버의 php버전이 낮아서 json_encode() 함수가 안될때 사용하는 함수

//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개

오 찾았던 자료네요 ㅠㅠ 감사합니다
댓글을 작성하시려면 로그인이 필요합니다.

프로그램

+
제목 글쓴이 날짜 조회
13년 전 조회 2,033
13년 전 조회 4,029
13년 전 조회 4,424
13년 전 조회 2,465
13년 전 조회 1.2만
13년 전 조회 2,583
13년 전 조회 1,671
13년 전 조회 2,567
13년 전 조회 4,331
13년 전 조회 8,382
13년 전 조회 1만
13년 전 조회 4,070
13년 전 조회 4,213
13년 전 조회 7,844
13년 전 조회 1.2만
13년 전 조회 5,268
13년 전 조회 1,826
13년 전 조회 2,116
13년 전 조회 3,597
13년 전 조회 1,958
13년 전 조회 4,935
13년 전 조회 1,679
13년 전 조회 4,201
13년 전 조회 4,687
13년 전 조회 3,302
13년 전 조회 3,437
13년 전 조회 4,517
13년 전 조회 1,949
13년 전 조회 4,124
13년 전 조회 6,456
13년 전 조회 2,919
13년 전 조회 2,590
13년 전 조회 2,507
13년 전 조회 2,415
13년 전 조회 2,163
13년 전 조회 4,416
13년 전 조회 2,071
13년 전 조회 2,761
13년 전 조회 7,086
13년 전 조회 4,469
13년 전 조회 3,864
13년 전 조회 4,350
13년 전 조회 2,705
13년 전 조회 1,997
13년 전 조회 2,445
13년 전 조회 2,480
13년 전 조회 1,813
13년 전 조회 4,784
13년 전 조회 5,183
13년 전 조회 3,527
13년 전 조회 9,529
13년 전 조회 2,128
13년 전 조회 9,968
13년 전 조회 1.8만
13년 전 조회 2,476
13년 전 조회 1,959
13년 전 조회 7,482
13년 전 조회 1,970
13년 전 조회 2,150
13년 전 조회 1,927
13년 전 조회 2,051
13년 전 조회 2,360
13년 전 조회 2,209
13년 전 조회 2,309
13년 전 조회 4,868
13년 전 조회 3,340
13년 전 조회 5,620
13년 전 조회 4,285
13년 전 조회 5,469
13년 전 조회 3,293
13년 전 조회 2,513
13년 전 조회 2,195
13년 전 조회 3,302
13년 전 조회 6,231
13년 전 조회 2,469
13년 전 조회 5,344
13년 전 조회 6,892
13년 전 조회 2,527
13년 전 조회 3,770
13년 전 조회 2,874
13년 전 조회 1,850
13년 전 조회 3,555
13년 전 조회 3,247
13년 전 조회 2,030
13년 전 조회 1,913
13년 전 조회 4,460
13년 전 조회 2,853
13년 전 조회 1,834
13년 전 조회 1,754
13년 전 조회 9,386
13년 전 조회 5,902
13년 전 조회 9,048
13년 전 조회 1,990
13년 전 조회 2,638
13년 전 조회 3,064
13년 전 조회 2,483
13년 전 조회 4,002
13년 전 조회 2,243
13년 전 조회 2,383
13년 전 조회 1,830