1. ob 함수 소개
1.1, ob_start - 출력 제어 버퍼 켜기
bool ob_start ([ callback $output_callback [, int $chunk_size [, bool $erase ]]] )이 함수는 출력 버퍼를 엽니다. 출력 버퍼링이 활성화되면 스크립트는 콘텐츠(http 헤더 제외)를 출력하지 않고 대신 출력할 콘텐츠를 내부 버퍼에 저장합니다.
자세한 내용 참조:
1.2, ob_get_contents - 출력 버퍼의 내용 반환
string ob _get_contents (void)그냥 가져옵니다 버퍼 내용을 출력하지만 지우지는 않습니다.
자세한 내용은 다음을 참조하세요.
1.3, ob_end_flush - 출력 버퍼 내용을 플러시(전송)하고 버퍼를 닫습니다.
bool ob_end_flush (void)이 함수는 최상위 버퍼의 내용을 전송하고(내용이 있는 경우) 버퍼를 닫습니다. 버퍼의 내용을 추가로 처리하려면 ob_end_flush() 전에 ob_get_contents()를 호출해야 합니다. 왜냐하면 ob_end_flush()를 호출한 후에 버퍼 내용이 삭제되기 때문입니다.
자세한 내용은 참조:
1.4, ob_flush - 출력 버퍼의 콘텐츠를 플러시(전송)합니다
void ob_flush (void)이 함수는 버퍼의 내용을 보냅니다(내용이 있는 경우). 버퍼의 내용을 추가로 처리하려면 ob_flush() 전에 ob_get_contents()를 호출해야 합니다. 왜냐하면 버퍼 내용은 ob_flush()를 호출한 후에 삭제되기 때문입니다.
이 함수는 출력 버퍼를 파괴하지 않지만, ob_end_flush()와 같은 함수는 버퍼를 파괴합니다.
자세한 내용은 참조:
1.5, ob_get_clean - 현재 버퍼의 내용을 가져오고 현재 출력 버퍼를 삭제합니다
string ob_get_clean (void)현재 버퍼의 내용을 가져오고 현재 출력 버퍼를 삭제합니다.
ob_get_clean()은 기본적으로 ob_get_contents()와 ob_end_clean()을 함께 실행합니다.
자세한 내용 참조:
1.6, ob_get_flush - 문자열 형식으로 버퍼 내용 플러시(보내기) 콘텐츠 및 출력 버퍼링 닫기 구역
string ob_get_flush (void )ob_get_flush()는 버퍼의 내용을 플러시(전송)하고, 내용을 문자열로 반환하고, 출력 버퍼를 닫습니다.
참고: 이 함수는 버퍼 내용을 문자열 형식으로 반환한다는 점을 제외하면 ob_end_flush()와 유사합니다.
자세한 내용은 참고:
) HTML 정적 페이지를 만드는 함수
2.1, 간단한 출력 HTML 파일
5d4b5886791e07962c78bfaea7aeac8equery($sql);$arr = array();while($ re = $result->fetch(PDO::FETCH_ASSOC)){ $arr[] = $re;} //html 파일로 출력 내용 루프 ob_start() //버퍼 열기 ?> < ;!-- 다음은 출력 내용입니다-->8b05045a5be5764f313ed5b9168a17e649099650ebdc5f3125501fa17004892393f0f5c25f18dab9d176bd4f6de5d30e4803e0c0eb005b8a0c00cc7b601af846 루프 출력 HTML 콘텐츠6e916e0f7d1e588d4f442bf645aedb2f9c3bca370b5104690d9ef395f2c5f8d16c04bd5ca3fcae76e30b72ad730ca86df5d188ed2c074f8b944552db028f98a1ae20bdd317918ca68efdc799512a9b39a34de1251f0d9fe1e645927f19a896e8b6c5a531a458a2e790c1fd6421739d1cpwdb90dd5946f0946207856a8a37f441edf
fd273fcf5bcad3dfdad3c41bd81ad3e5
7943277d65306330563feb42dc8c705a
92cee25da80fac49f6fb6eec5fd2c22a
baba3a0b5d58f73e871ce2070dc611a9 $value) {
echo "a34de1251f0d9fe1e645927f19a896e8";
echo "b6c5a531a458a2e790c1fd6421739d1c{$value['id']}b90dd5946f0946207856a8a37f441edf";
echo "b6c5a531a458a2e790c1fd6421739d1c{$value[ 'name']}b90dd5946f0946207856a8a37f441edf";
echo "b6c5a531a458a2e790c1fd6421739d1c{$value['pwd']}b90dd5946f0946207856a8a37f441edf";
echo "fd273fcf5bcad3dfdad3c41bd81ad3e5";
}
?> ;
ca745a59da05f784b8811374296574e1
f16b1740fad44fb09bfe928bcc527e08
36cc49f0c466276486e50c850b7e4956
73a6ac4ed44ffec12cee46588e518a5e
a7beb3b1ae0e47564328b74acbcf0dd7
결과를 index2.html
에 출력합니다. ㅋㅋㅋ 지정된 파일을 읽었는지 확인하기 위해 올바르게
<?php $fileName = 'index2.html'; $re = file_exists($fileName);//判断文件是否存在 $dValue = 0;if($re){ $fileTime = filectime($fileName);//时间戳 $dValue = time() - $fileTime;//获取创建时间,文件缓存一般存在有效期}if(file_exists($fileName) && $dValue < 3600){ $content = file_get_contents($fileName); echo $content; die;}else{if($re){ unlink($fileName);//过去先删除,} require_once 'coon.php'; $sql = "select * from name order by id;"; $result = $link->query($sql); $arr = array();while($re = $result->fetch(PDO::FETCH_ASSOC)){ $arr[] = $re;} //循环输出内容到html文件 ob_start(); //打开缓冲区 ?><!-- 下面是输出的内容 --><!DOCTYPE html><html lang="en"><head><meta charset="UTF-8"><title>循环输出的html内容</title></head> <body> <table> <thead> <tr> <td>id</td><td>name</td> <td>pwd</td></tr> </thead><tbody><?php foreach ($arr as $key => $value) { echo "<tr>"; echo "<td>{$value['id']}</td>"; echo "<td>{$value['name']}</td>"; echo "<td>{$value['pwd']}</td>"; echo "</tr>";}?></tbody> </table></body> </html><?php $content = ob_get_contents();//得到当前缓冲区的内容ob_end_clean();//删除当前输出缓file_put_contents('index2.html',$content);//写入文件}?>
먼저 파일이 존재하는지 확인합니다. 존재하는 경우 현재 시간과 생성 시간의 시간 차이를 확인하여 현재 파일이 유효한지 확인합니다.
3. 요약
1. 서버에서 실행할 필요가 없으며, 접속 시 서버는 단순히 파일을 브라우저에 반환하고 어떠한 작업도 수행하지 않습니다.
2. 보안, 동적 웹 사이트 개발 언어는 절대 안전하지 않지만 정적 웹 페이지에는 서버가 해킹되는 것 외에는 프로그램에 허점이 없습니다