유용한 함수 - 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,344
14년 전 조회 1,498
14년 전 조회 1,301
14년 전 조회 1,639
14년 전 조회 2,937
14년 전 조회 2,361
14년 전 조회 2,214
14년 전 조회 3,653
14년 전 조회 2,742
14년 전 조회 1,712
14년 전 조회 1,761
14년 전 조회 1,733
14년 전 조회 1,851
14년 전 조회 1,317
14년 전 조회 1,627
14년 전 조회 1,761
14년 전 조회 3,337
14년 전 조회 1,647
14년 전 조회 1,386
14년 전 조회 1,385
14년 전 조회 3,728
14년 전 조회 1,502
14년 전 조회 2,197
14년 전 조회 2,238
14년 전 조회 1,433
14년 전 조회 2,104
14년 전 조회 1,521
14년 전 조회 1,644
14년 전 조회 2,563
14년 전 조회 2,304
14년 전 조회 2,914
14년 전 조회 1,620
14년 전 조회 1,507
14년 전 조회 2,880
14년 전 조회 1,531
14년 전 조회 1,657
14년 전 조회 2,775
14년 전 조회 1,756
14년 전 조회 1,697
14년 전 조회 1,417
14년 전 조회 1,656
14년 전 조회 2,688
14년 전 조회 1,269
14년 전 조회 3,231
14년 전 조회 1,583
14년 전 조회 1,308
14년 전 조회 1,282
14년 전 조회 1,537
14년 전 조회 1,460
14년 전 조회 1,368
14년 전 조회 1,865
14년 전 조회 1,297
14년 전 조회 1,917
14년 전 조회 2,304
14년 전 조회 1,275
14년 전 조회 1,414
14년 전 조회 1,258
14년 전 조회 1,432
14년 전 조회 1,844
14년 전 조회 1,544
14년 전 조회 1,662
14년 전 조회 1,471
14년 전 조회 1,636
14년 전 조회 1,223
14년 전 조회 2,082
14년 전 조회 1,420
14년 전 조회 2,166
14년 전 조회 8,917
14년 전 조회 1,517
14년 전 조회 2,355
14년 전 조회 2,085
14년 전 조회 2,341
14년 전 조회 2,728
14년 전 조회 1,311
14년 전 조회 1,453
14년 전 조회 7,247
14년 전 조회 1,416
14년 전 조회 1,347
14년 전 조회 2,520
14년 전 조회 1,410
14년 전 조회 1,408
14년 전 조회 2,883
14년 전 조회 1,488
14년 전 조회 4,397
14년 전 조회 4,522
14년 전 조회 1,867
14년 전 조회 1,434
14년 전 조회 2,100
14년 전 조회 1,383
14년 전 조회 1,678
14년 전 조회 1,263
14년 전 조회 8,167
14년 전 조회 1,803
14년 전 조회 1,210
14년 전 조회 1,367
14년 전 조회 2,071
14년 전 조회 1,502
14년 전 조회 1,374
14년 전 조회 1,461
14년 전 조회 1,369