fwrite() 함수 관련 입니다.

· 10년 전 · 591

웹 프로그램 제작 중에 관리자 모드에서 변경이 가능한 설정들 저장 방식을
DB로 할 것인가 파일로 할 것인가 고민하다가 파일쪽으로 눈을 돌렸습니다.

제가 고민이였던 부분은 파일로 할 경우
예를 들어 관리자 모드에서 설정을 변경하여
config.php에 "<?php $config = TRUE ?>" 내용을 저장할 경우

파일에 내용을 쓰는 도중에 "<?php $conf"까지 입력하였는데
갑자기 다른 페이지에서 config.php 파일 요청이 들어올 경우
쓰다가 만 파일을 읽어와 구문 오류로 인하여 페이지 자체가 보이지 않을까하는 불안감이 있었습니다.

직접 2개의 파일로 테스트를 해보았습니다.
-- index.php --
<?php
set_time_limit(5);
for ($i = 1; $i <= 100000000; $i++)
{
include './config.php';
}

-- save.php --
<?php
sleep(3);
$str = 'testa';
$str = str_pad($str, 11111111, "_");

$fp = fopen('./config.php', 'w');
fwrite($fp, "<?php \necho '<br>'.\$i;\n\"{$str}\";");
fclose($fp);

save.php 파일을 실행시키고 index.php에서 지속적으로 config.php을 불러올 경우
테스트를 해보니 다행이도 구문 오류는 나지 않고 타임아웃만 났습니다.

여러대의 서버를 묶어서 쓰거나 이런 경우는 테스트를 해보지 않았습니다만...
다행이 OS단에서 처리하는 것 같습니다 ^^....

이왕 테스트하는 김에 이번엔 내용 문자를 2개로 나눠서
fwrite() 함수를 2번 실행시키게 하였습니다.

-- save2.php --
<?php
sleep(3);
$str = 'testa';
$str = str_pad($str, 11111111, "_");

$fp = fopen('./config.php', 'w');
fwrite($fp, "<?php \necho '<br>'.\$i;\n\"");
fwrite($fp, "{$str}\";");

fclose($fp);

내용을 보면 첫번째 fwrite()만 작동시켰을 경우 구문 오류가 나도록 고치고
두번째 fwrite()에서 나머지 내용을 쓰도록 하였습니다.

fwrite()을 두번 실행시켰을 경우 그 사이에 다른 파일의 요청이 들어올 경우
가져갈 수 있었습니다....
실행시 문법 오류가 있었습니다.....

결론
1. 한번에 fwrite()을 쓸 것
2. fwrite()로 파일을 쓰는 짧은 시간동안은 외부에서 긁어가지 못함.

|
댓글을 작성하시려면 로그인이 필요합니다. 로그인

프로그램

+
제목 글쓴이 날짜 조회
10년 전 조회 507
10년 전 조회 524
10년 전 조회 638
10년 전 조회 547
10년 전 조회 485
10년 전 조회 501
10년 전 조회 505
10년 전 조회 464
10년 전 조회 473
10년 전 조회 683
10년 전 조회 891
10년 전 조회 696
10년 전 조회 501
10년 전 조회 504
10년 전 조회 458
10년 전 조회 484
10년 전 조회 583
10년 전 조회 519
10년 전 조회 434
10년 전 조회 483
10년 전 조회 877
10년 전 조회 1,328
10년 전 조회 898
10년 전 조회 695
10년 전 조회 669
10년 전 조회 531
10년 전 조회 520
10년 전 조회 540
10년 전 조회 511
10년 전 조회 527
10년 전 조회 551
10년 전 조회 682
10년 전 조회 589
10년 전 조회 1,326
10년 전 조회 879
10년 전 조회 599
10년 전 조회 673
10년 전 조회 937
10년 전 조회 654
10년 전 조회 785
10년 전 조회 630
10년 전 조회 735
10년 전 조회 568
10년 전 조회 544
10년 전 조회 542
10년 전 조회 592
10년 전 조회 548
10년 전 조회 608
10년 전 조회 613
10년 전 조회 592
10년 전 조회 753
10년 전 조회 763
10년 전 조회 528
10년 전 조회 831
10년 전 조회 1,185
10년 전 조회 635
10년 전 조회 868
10년 전 조회 862
10년 전 조회 696
10년 전 조회 631
10년 전 조회 614
10년 전 조회 715
10년 전 조회 489
10년 전 조회 523
10년 전 조회 740
10년 전 조회 570
10년 전 조회 532
10년 전 조회 515
10년 전 조회 526
10년 전 조회 535
10년 전 조회 515
10년 전 조회 533
10년 전 조회 554
10년 전 조회 647
10년 전 조회 482
10년 전 조회 507
10년 전 조회 594
10년 전 조회 1,343
10년 전 조회 546
10년 전 조회 543
10년 전 조회 673
10년 전 조회 556
10년 전 조회 740
10년 전 조회 655
10년 전 조회 542
10년 전 조회 544
10년 전 조회 599
10년 전 조회 589
10년 전 조회 486
10년 전 조회 482
10년 전 조회 451
10년 전 조회 493
10년 전 조회 890
10년 전 조회 500
10년 전 조회 618
10년 전 조회 531
10년 전 조회 735
10년 전 조회 539
10년 전 조회 464
10년 전 조회 510
🐛 버그신고