나중에 쉽게 참고할 수 있도록 PHP에서 파일을 읽는 여러 가지 방법을 정리했습니다.
1.fread
문자열 fread( int $handle , int $length )
fread()는 핸들이 가리키는 파일에서 최대 길이 바이트를 읽습니다. 이 함수는 length 바이트까지 읽은 후, EOF에 도달한 경우, 또는 (네트워크 스트림의 경우) 패킷을 사용할 수 있는 경우 또는 (사용자 공간 스트림을 연 후) 8192바이트를 읽은 후 호출됩니다. 어떤 조건이 먼저 발생하는지에 따라 다릅니다.
fread()는 읽은 문자열을 반환하거나, 오류가 발생하면 FALSE를 반환합니다.
읽고자 하는 파일이 로컬 일반 파일이 아니고 원격 파일이나 스트림 파일인 경우에는 filesize로 해당 파일의 크기를 얻을 수 없기 때문에 이 방법을 사용할 수 없습니다. 이 시점에서 feof() 또는 fread()의 반환 값을 사용하여 파일의 끝을 읽었는지 확인해야 합니다.
예:
또는:
2.fgets
string fgets( int $handle [, int $length ] )
fgets()는 핸들이 가리키는 파일에서 한 줄을 읽고 최대 길이가 1바이트인 문자열을 반환합니다. 개행 문자(반환 값에 포함됨), EOF 또는 길이 - 1바이트를 읽었을 때(둘 중 먼저 발생하는 것) 중지됩니다. 길이를 지정하지 않으면 기본값은 1K 또는 1024바이트입니다.
참고: 길이 매개변수는 PHP 4.2.0부터 선택사항이며, 생략할 경우 행 길이는 1024로 간주됩니다. PHP 4.3부터 길이를 생략하면 줄 끝까지 스트림에서 계속 읽혀집니다. 파일 내 라인의 대부분이 8KB보다 큰 경우 스크립트에서 최대 라인 길이를 지정하는 것이 리소스 활용에 더 효율적입니다. PHP 4.3부터 이 함수는 바이너리 파일과 함께 사용해도 안전합니다. 이전 버전에서는 그렇지 않았습니다.
3.fgetss
string fgetss(resource $handle [, int $length [, string $allowable_tags ]] )
fgets와 동일한 기능이지만 fgetss는 읽은 텍스트에서 HTML 및 PHP 태그를 제거하려고 시도합니다. 선택적 세 번째 매개변수를 사용하여 제거하지 않을 태그를 지정할 수 있습니다.
4.파일
배열 파일( 문자열 $filename [, int $use_include_path [, 자원 $context ]] )
파일 내용을 배열로 읽어옵니다. 배열의 각 항목은 줄 바꿈을 포함하여 파일의 한 줄에 해당합니다. 줄 종결자가 필요하지 않은 경우 rtrim() 함수를 사용하여 개행 문자를 필터링할 수 있습니다.
5.읽기파일
int readfile( 문자열 $filename [, bool $use_include_path [, 자원 $context ]] )
파일을 읽고 출력 버퍼에 씁니다. 파일에서 읽은 바이트 수를 반환합니다. 오류가 발생하면 FALSE를 반환하고 @readfile()로 호출하지 않으면 오류 메시지가 표시됩니다.
6.file_get_contents
string file_get_contents ( string $filename [, bool $use_include_path [, resources $context [, int $offset [, int $maxlen ]]]] )
파일을 문자열로 읽어옵니다. 세 번째 매개변수 $context는 원격 파일에 액세스할 때 시간 초과 설정 등 일부 매개변수를 설정하는 데 사용할 수 있습니다.
또한, file_get_contents는 위의 함수보다 성능이 훨씬 좋으므로 file_get_contents를 먼저 사용해야 합니다. 하지만 readfile은 fopen을 호출할 필요가 없기 때문에 file_get_contents(?)보다 성능이 더 좋은 것 같습니다.
7.fpassthru
int fpassthru(리소스 $handle)현재 위치에서 주어진 파일 포인터를 EOF까지 읽고 결과를 출력 버퍼에 씁니다.
8.parse_ini_file
배열 구문 분석_ini_file( 문자열 $filename [, bool $process_sections ] )
parse_ini_file()은 filename으로 지정된 ini 파일을 로드하고 해당 설정을 연관 배열로 반환합니다. 최종 process_sections 매개변수를 TRUE로 설정하면 구성 파일에 있는 각 섹션의 이름과 설정이 포함된 다차원 배열을 얻게 됩니다. process_sections의 기본값은 FALSE입니다.
참고:
1. ini 파일의 값에 영숫자가 아닌 문자가 포함된 경우 큰따옴표(")로 묶어야 합니다.
2. null, yes, no, true 및 false를 포함한 일부 예약어는 ini 파일의 키 이름으로 사용할 수 없습니다. null, no, false 값은 ""에 해당하고, yes, true 값은 "1"에 해당합니다. {}|&~![()" 문자도 키 이름 어디에도 사용할 수 없으며 이러한 문자는 옵션 값에서 특별한 의미를 갖습니다.
test.ini 파일 내용:
[첫 번째_섹션]
하나 = 1
5 = 5
동물 = 새
[두 번째_섹션]
경로 = "/usr/local/bin"
URL = "http://www.example.com/~사용자 이름
test.php 콘텐츠:
출력 콘텐츠:
)
)
몇 가지 참고 사항:
2.allow_url_fopen 옵션은 파일 등의 URL 객체에 접근할 수 있도록 fopen 캡슐화 프로토콜의 URL 형식을 활성화합니다. 기본 캡슐화 프로토콜은 ftp 및 http 프로토콜을 사용하여 원격 파일에 대한 액세스를 제공합니다. zlib와 같은 일부 확장 라이브러리는 더 많은 캡슐화 프로토콜을 등록할 수 있습니다. 보안상의 이유로 이 옵션은 php.ini에서만 설정할 수 있습니다.
3. 특수 문자(예: 공백)가 포함된 URL을 열려면 URL 인코딩에 urlencode()를 사용해야 합니다.