1. 개념
PHP 실행 중에 출력을 생성하는 함수나 연산 결과는 버퍼가 가득 차거나 PHP 실행이 완료된 경우에만 임시로 PHP 버퍼에 저장할 수 있습니다. 데이터는 출력이 필요할 때만 브라우저에 출력됩니다. 데이터를 버퍼링하는 이 영역을 PHP의 출력 버퍼(OB)라고 합니다.
2. 원리
① 버퍼를 사용한 후 PHP를 실행할 때 echo, print_r 등의 데이터를 출력하는 코드를 만나면(사실 많은 함수에서 출력이 생성됩니다.) PHP는 출력 데이터를 PHP 자체 버퍼, 출력을 기다리는 중
② PHP 자체 버퍼는 버퍼의 내용을 출력하라는 명령을 받으면 버퍼에 있는 데이터를 서버로 출력합니다. PHP에서 출력된 데이터를 받은 후 저장합니다.
3 서버가 명령을 받고 버퍼의 내용만 출력하려고 하면 버퍼의 내용을 출력하고 브라우저로 돌아갑니다.
위에서 볼 수 있듯이 출력 버퍼 레이어는 출력을 버퍼링하는 데 사용되는 유일한 레이어가 아니며 실제로는 여러 레이어 중 하나일 뿐입니다. 마지막으로 기억해야 할 점은 출력 버퍼 계층의 동작이 사용 중인 SAPI(웹 또는 CLI)와 관련이 있다는 것입니다. SAPI마다 동작이 다를 수 있습니다.
첫 번째 개념에서 언급했듯이 버퍼가 가득 차면 버퍼링된 데이터가 출력됩니다. 이는 SAPI와 관련이 있으며 주로 php.ini의 output_buffering 변수를 통해 제어됩니다. Output_buffering의 기본값은 on이고, 기본값은 4096(4kb)입니다.
3. 출력 버퍼 구성
1. 우리가 일반적으로 사용하는 PHP-FPM의 SAPI를 예로 들면 다음은 PHP의 ini 파일 구성을 요약한 것입니다. 주로 세 가지 옵션이 있습니다.
output_buffering
implicit_flush
output_handler
표를 사용하여 이 세 가지 매개변수의 의미를 명확히 합니다.
위 세 가지 값은 런타임 시 ini_set()을 사용하여 변경할 수 없다는 점에 유의하세요.
2. PHP CLI 모드에서 실행 시 구성과 관련하여 몇 가지 주의할 점이 있습니다.
(1) 출력_버퍼링 매개변수는 기본적으로 활성화되지 않습니다.
(2) 암시적_플러시 매개변수 기본적으로 1(켜짐)로 설정됩니다.
3.output_handler 설정 콜백 함수에 대해서는 몇 가지 공통 설정을 참조하십시오.
①ob_gzhandler: 출력을 압축하려면 ext/zlib를 사용합니다.
②mb_output_handler: 문자 인코딩을 변환하려면 ext/mbstring을 사용합니다. iconv 변환 문자 인코딩
4ob_tidyhandler: ext/tidy를 사용하여 출력 HTML 텍스트 정리
⑤ob_[inflate/deflate]_handler: ext/http를 사용하여 출력 압축
⑥ob_etaghandler: 자동 생성 HTTP Etag;
4. 출력 버퍼 관련 방법
ob_start(); //출력 버퍼를 엽니다. 모든 출력 정보는 더 이상 다음 레이어로 직접 전송되지 않고 출력 버퍼에 저장됩니다.
ob_clean(); //버퍼를 닫지 않고(출력 없음) 내부 버퍼의 내용을 삭제합니다. ob_end_clean(); //내부 버퍼의 내용을 삭제하고 버퍼를 닫습니다(출력 없음).
ob_get_clean(); //내부 버퍼의 내용을 반환하고 버퍼를 닫습니다.
ob_flush(); //버퍼 내용을 다음 레이어로 보내고, 버퍼 내용을 삭제하고, 버퍼를 닫지 않습니다.
ob_end_flush(); //버퍼 내용을 다음 레이어로 보내고, 버퍼 내용을 삭제하고, 버퍼를 닫습니다.
ob_get_flush(); //버퍼의 내용을 반환하고 버퍼를 닫은 다음 버퍼의 내용을 해제합니다.
ob_get_contents(); //출력 없이 버퍼의 내용을 반환합니다.
ob_get_length(); //버퍼의 길이를 반환합니다. 버퍼가 활성화되지 않은 경우 FALSE를 반환합니다.
ob_get_status() ; //모든 출력 버퍼의 상태를 가져옵니다.
ob_implicit_flush(); //절대 플러시를 켜거나 끕니다.
1. 세션, 쿠키, 헤더 및 기타 설정 기능 전에 열기:
가장 일반적인 것은 헤더 기능을 사용하기 전에 일부 데이터가 출력되어 특정 오류가 발생한다는 것입니다. , 헤더 정보를 수정할 수 없습니다.
에서 이미 보낸 헤더입니다. 이 오류가 발생하는 이유는 일부 데이터가 헤더 이전에 출력되었기 때문이며, 이 데이터를 출력하는 동안 서버는 브라우저( 출력이 있기 때문에(즉, 요청이 유효함) 헤더 기능을 다시 사용하여 http 헤더를 보내면 이 오류가 반환됩니다. 오류는 다음을 의미합니다. HTTP 헤더가 전송되었으므로 더 이상 수정할 수 없습니다. 그것을 할 수 있습니다.
그래서 처음에 ob_start 메소드를 활성화할 수 있습니다.
2. PHP 프로그램의 다운로드 기능 제어:
보통 많은 사람들이 PHP를 사용하여 파일을 다운로드하지만 파일 크기가 너무 큰 경우(예: 100M) 먼저 메모리로 읽어온 다음 전송합니다. 사용자에게 응답시간이 크게 길어지고(심지어 타임아웃), 메모리 사용량도 크게 늘어납니다(심지어 오버플로).
출력 버퍼링을 사용하면 읽은 파일을 버퍼로 읽어 들여 특정 크기에 도달하면 사용자에게 전송한 다음 계속해서 읽어 샤딩 효과를 얻을 수 있습니다. 이런 방식으로 브라우저는 모든 파일을 읽을 때까지 기다리지 않고도 계속해서 데이터를 수신할 수 있으며 메모리도 많이 차지하지 않습니다.
3. 정적 파일 캐시:
여러 번 읽어야 하고 수정 빈도가 매우 낮은 파일은 처음 읽을 때 버퍼에 저장되어 정적 파일을 생성할 수 있습니다. PHP 처리(데이터베이스 읽기 등)를 거치지 않고 바로 Return 합니다.
PHP 관련 기술 기사를 더 보려면 PHP 튜토리얼 칼럼을 방문하여 알아보세요!
위 내용은 PHP를 기반으로 출력버퍼의 기본 개념 및 원리 분석의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!