유용한 함수 - serialize

안녕하세요 유창화입니다.

가끔 유용한 함수 하나씩 올려볼까 합니다.
물론, 아시는 분들은 많으리라고 예상합니다.

하지만, 모르시는 분들을 위해 가끔씩 올려보도록 하겟습니다.

serialize -> 인자로 받은 변수를 일렬화된 문자로 반환 합니다.

그러니까

$a = Array();
$a['title'] = '아름다운 우리나라';
$a['content'] = '어쩌구 저쩌구......';
이런 배열이 있다고 가정할 때

$b = serialize($a);// a:2:{s:5:"title";s:17:"아름다운 우리나라";s:7:"content";s:19:"어쩌구 저쩌구......";} 
serialize 를 사용하여 다른 변수에 저장할수 있습니다.

반대로 unserialize 를 사용하면 원래의 변수를 받을수 있습니다.

$a = unserialize($b);

저는 이것을 주로
간단하게 파일 캐쉬 작업을 할때 주로 사용하는데요
데이타베이스는 사용하지 않고 파일로서만 특정데이타를 저장하고 반환하고자 할때 주로 많이 사용합니다.

$save_file = 'a.txt';
if (!is_file($save_file) || filemtime($save_file) + 3600 < time()) {

    $a = Array();
    $a['title'] = '아름다운 우리나라';
    $a['content'] = '어쩌구 저쩌구......';

    $b = serialize($a);
    file_put_contents($save_file, $b);
}
else {
    
    $save_text = file_get_contents($save_file);
    $a = unserialize($b);
}




|

댓글 6개

앗 여긴 추천이 없구나.....
다른데 써야 겟네요.
팁에 올려주세요. 추천 1 대기요.
전 DB캐쉬할때

if($_SESSION['sample_cache'] == ''){
//쿼리문 생략
$res = mysql_fetch_array(mysql_query($sql));
$_SESSION['sample_cache'] = json_encode($res);
}
else{
$res = get_object_vars(json_decode($_SESSION['business_count']));
}

echo $res['sample_data'];
json이 object라서 get_object_vars 함수를 사용해야 하지만
공통 규격이라서 다른서버간 통신, 다른언어간 통신, 앱과 통신 할때 유용하더라구요.
오 좋은글 감사합니다...^ ^
댓글을 작성하시려면 로그인이 필요합니다.

프로그램

+
제목 글쓴이 날짜 조회
14년 전 조회 2,430
14년 전 조회 1,585
14년 전 조회 1,372
14년 전 조회 1,729
14년 전 조회 3,022
14년 전 조회 2,438
14년 전 조회 2,291
14년 전 조회 3,723
14년 전 조회 2,830
14년 전 조회 1,788
14년 전 조회 1,846
14년 전 조회 1,806
14년 전 조회 1,922
14년 전 조회 1,382
14년 전 조회 1,700
14년 전 조회 1,837
14년 전 조회 3,393
14년 전 조회 1,699
14년 전 조회 1,454
14년 전 조회 1,439
14년 전 조회 3,798
14년 전 조회 1,566
14년 전 조회 2,269
14년 전 조회 2,307
14년 전 조회 1,499
14년 전 조회 2,175
14년 전 조회 1,585
14년 전 조회 1,702
14년 전 조회 2,642
14년 전 조회 2,368
14년 전 조회 2,985
14년 전 조회 1,682
14년 전 조회 1,571
14년 전 조회 2,959
14년 전 조회 1,591
14년 전 조회 1,719
14년 전 조회 2,834
14년 전 조회 1,832
14년 전 조회 1,766
14년 전 조회 1,483
14년 전 조회 1,730
14년 전 조회 2,757
14년 전 조회 1,332
14년 전 조회 3,303
14년 전 조회 1,646
14년 전 조회 1,363
14년 전 조회 1,355
14년 전 조회 1,614
14년 전 조회 1,523
14년 전 조회 1,433
14년 전 조회 1,932
14년 전 조회 1,345
14년 전 조회 1,985
14년 전 조회 2,365
14년 전 조회 1,342
14년 전 조회 1,487
14년 전 조회 1,314
14년 전 조회 1,483
14년 전 조회 1,910
14년 전 조회 1,612
14년 전 조회 1,728
14년 전 조회 1,531
14년 전 조회 1,710
14년 전 조회 1,285
14년 전 조회 2,143
14년 전 조회 1,483
14년 전 조회 2,235
14년 전 조회 8,983
14년 전 조회 1,573
14년 전 조회 2,416
14년 전 조회 2,157
14년 전 조회 2,402
14년 전 조회 2,776
14년 전 조회 1,371
14년 전 조회 1,504
14년 전 조회 7,300
14년 전 조회 1,473
14년 전 조회 1,405
14년 전 조회 2,586
14년 전 조회 1,462
14년 전 조회 1,459
14년 전 조회 2,924
14년 전 조회 1,531
14년 전 조회 4,440
14년 전 조회 4,572
14년 전 조회 1,924
14년 전 조회 1,475
14년 전 조회 2,162
14년 전 조회 1,437
14년 전 조회 1,739
14년 전 조회 1,326
14년 전 조회 8,225
14년 전 조회 1,870
14년 전 조회 1,271
14년 전 조회 1,423
14년 전 조회 2,127
14년 전 조회 1,564
14년 전 조회 1,431
14년 전 조회 1,513
14년 전 조회 1,433