찾다
백엔드 개발PHP 문제PHP에서 텍스트를 읽는 방법

PHP에서 텍스트를 읽는 방법

php 텍스트를 읽는 방법은 무엇인가요?

php에서 파일 내용을 읽는 여러 가지 방법

1.fread

  string fread ( int $handle , int $length )

fread( )은 핸들이 가리키는 파일에서 최대 길이 바이트를 읽습니다. 이 함수는 length 바이트까지 읽은 후, EOF에 도달한 경우, 또는 (네트워크 스트림의 경우) 패킷을 사용할 수 있는 경우 또는 (사용자 공간 스트림을 연 후) 8192바이트를 읽은 후 호출됩니다. 어떤 조건이 먼저 발생하는지에 따라 다릅니다.

권장 사항: "PHP Tutorial"

 fread()는 읽은 문자열을 반환하고, 오류가 발생하면 FALSE를 반환합니다.

<?php
    $filename = "/usr/local/something.txt";
    $handle = fopen($filename, "r");//读取二进制文件时,需要将第二个参数设置成&#39;rb&#39;
    
    //通过filesize获得文件大小,将整个文件一下子读到一个字符串中
    $contents = fread($handle, filesize ($filename));
    fclose($handle);
?>

읽어올 파일이 로컬 일반 파일이 아닌 원격 파일이나 스트림 파일인 경우에는 filesize로 해당 파일의 크기를 얻을 수 없으므로 이 방법을 사용할 수 없습니다. 이때 파일의 끝을 읽었는지 여부를 확인하려면 feof() 또는 fread()의 반환 값을 사용해야 합니다.

예:

<?php
    $handle = fopen(&#39;http://www.baidu.com&#39;, &#39;r&#39;);
    $content = &#39;&#39;;
    while(!feof($handle)){
        $content .= fread($handle, 8080);
    }
    echo $content;
    fclose($handle);
?>

또는

<?php
    $handle = fopen(&#39;http://www.baidu.com&#39;, &#39;r&#39;);
    $content = &#39;&#39;;
    while(false != ($a = fread($handle, 8080))){//返回false表示已经读取到文件末尾
        $content .= $a;
    }
    echo $content;
    fclose($handle);
?>

2.fgets

  string fgets ( int $handle [, int $length ] )
#🎜🎜 # fgets()는 핸들이 가리키는 파일에서 한 줄을 읽고 최대 길이 - 1바이트의 문자열을 반환합니다. 개행 문자(반환 값에 포함됨), EOF 또는 길이 - 1바이트를 읽었을 때(둘 중 먼저 발생하는 것) 중지됩니다. 길이를 지정하지 않으면 기본값은 1K 또는 1024바이트입니다.

<?php
    $handle = fopen(&#39;./file.txt&#39;, &#39;r&#39;);
    while(!feof($handle)){
        echo fgets($handle, 1024);
    }
    fclose($handle);
?>

 참고: 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 태그를 제거하려고 시도합니다. 선택적인 세 번째 매개변수를 사용하여 태그를 지정할 수 있습니다. 제거되지 않습니다.

<?php
    $handle = fopen(&#39;./file.txt&#39;, &#39;r&#39;);
    while(!feof($handle)){
        echo fgetss($handle, 1024, &#39;<br>&#39;);
    }
    fclose($handle);
?>

4.file

  array file ( string $filename [, int $use_include_path [, resource $context ]] )

배열의 각 항목은 파일의 한 줄에 해당합니다. 줄바꿈 포함. 줄 종결자가 필요하지 않은 경우 rtrim() 함수를 사용하여 개행 문자를 필터링할 수 있습니다.

<?php
    $a = file(&#39;./file.txt&#39;);
    foreach($a as $line => $content){
        echo &#39;line &#39;.($line + 1).&#39;:&#39;.$content;
    }
?>

5.readfile

  int readfile ( string $filename [, bool $use_include_path [, resource $context ]] )

파일을 읽고 출력 버퍼에 씁니다. 파일에서 읽은 바이트 수를 반환합니다. 오류 시 FALSE를 반환하고 @readfile()로 호출하지 않으면 오류 메시지를 표시합니다.

<?php
    $size = readfile(&#39;./file.txt&#39;);
    echo $size;
?>

6.file_get_contents

  string file_get_contents ( string $filename [, bool $use_include_path [, resource $context [, int $offset [, int $maxlen ]]]] )

파일을 문자열로 읽어옵니다. 세 번째 매개변수 $context는 원격 파일에 액세스할 때 시간 초과 설정 등 일부 매개변수를 설정하는 데 사용할 수 있습니다.

게다가 위 함수들에 비해 file_get_contents의 성능이 훨씬 좋기 때문에 file_get_contents에 우선순위를 주어야 합니다. 하지만 readfile은 fopen을 호출할 필요가 없기 때문에 file_get_contents(?)보다 성능이 더 좋은 것 같습니다.

<?php 
    $ctx = stream_context_create(array( 
        &#39;http&#39; => array( 
            &#39;timeout&#39; => 1    //设置超时
            ) 
        ) 
    ); 
    echo file_get_contents("http://www.baidu.com/", 0, $ctx); 
?>

7.fpassthru

   int fpassthru ( resource $handle )

주어진 파일 포인터를 현재 위치에서 EOF까지 읽고 결과를 출력 버퍼에 씁니다.

<?php 
    header("Content-Type:text/html;charset=utf-8"); 
    $handle = fopen(&#39;./test2.php&#39;, &#39;r&#39;);
    fseek($handle, 1024);//将指针定位到1024字节处
    fpassthru($handle);
?>

몇 가지 참고 사항:

 1. 시스템이 그렇지 않은 경우에도 바이너리 파일을 처리할 때 b 플래그를 사용하는 것이 좋습니다. 필요하면 스크립트의 이식성을 높일 수 있습니다. ​

 2.allow_url_fopen 옵션은 파일과 같은 URL 개체에 액세스할 수 있도록 fopen 캡슐화 프로토콜의 URL 형식을 활성화합니다. 기본 캡슐화 프로토콜은 ftp 및 http 프로토콜을 사용하여 원격 파일에 대한 액세스를 제공합니다. zlib와 같은 일부 확장 라이브러리는 더 많은 캡슐화 프로토콜을 등록할 수 있습니다. 보안상의 이유로 이 옵션은 php.ini에서만 설정할 수 있습니다.

 3. 특수 문자(예: 공백)가 포함된 URL을 열려면 URL 인코딩에 urlencode()를 사용해야 합니다.

위 내용은 PHP에서 텍스트를 읽는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
산과 기본 데이터베이스 : 차이 및 각각을 사용 해야하는시기.산과 기본 데이터베이스 : 차이 및 각각을 사용 해야하는시기.Mar 26, 2025 pm 04:19 PM

이 기사는 산 및 기본 데이터베이스 모델을 비교하여 특성과 적절한 사용 사례를 자세히 설명합니다. 산은 금융 및 전자 상거래 애플리케이션에 적합한 데이터 무결성 및 일관성을 우선시하는 반면 Base는 가용성 및

PHP 보안 파일 업로드 : 파일 관련 취약점 방지.PHP 보안 파일 업로드 : 파일 관련 취약점 방지.Mar 26, 2025 pm 04:18 PM

이 기사는 코드 주입과 같은 취약점을 방지하기 위해 PHP 파일 업로드 보안에 대해 설명합니다. 파일 유형 유효성 검증, 보안 저장 및 오류 처리에 중점을 두어 응용 프로그램 보안을 향상시킵니다.

PHP 입력 유효성 검증 : 모범 사례.PHP 입력 유효성 검증 : 모범 사례.Mar 26, 2025 pm 04:17 PM

기사는 내장 함수 사용, 화이트리스트 접근 방식 및 서버 측 유효성 검사와 같은 기술에 중점을 둔 보안을 향상시키기 위해 PHP 입력 유효성 검증에 대한 모범 사례를 논의합니다.

PHP API 요율 제한 : 구현 전략.PHP API 요율 제한 : 구현 전략.Mar 26, 2025 pm 04:16 PM

이 기사는 토큰 버킷 및 누출 된 버킷과 같은 알고리즘을 포함하여 PHP에서 API 요율 제한을 구현하고 Symfony/Rate-Limiter와 같은 라이브러리 사용 전략에 대해 설명합니다. 또한 모니터링, 동적 조정 요율 제한 및 손도 다룹니다.

PHP 비밀번호 해싱 : password_hash 및 password_verify.PHP 비밀번호 해싱 : password_hash 및 password_verify.Mar 26, 2025 pm 04:15 PM

이 기사에서는 PHP에서 암호를 보호하기 위해 PHP에서 Password_hash 및 Password_Verify 사용의 이점에 대해 설명합니다. 주요 주장은 이러한 기능이 자동 소금 생성, 강한 해싱 알고리즘 및 Secur를 통해 암호 보호를 향상 시킨다는 것입니다.

OWASP Top 10 PHP : 일반적인 취약점을 설명하고 완화하십시오.OWASP Top 10 PHP : 일반적인 취약점을 설명하고 완화하십시오.Mar 26, 2025 pm 04:13 PM

이 기사는 PHP 및 완화 전략의 OWASP Top 10 취약점에 대해 설명합니다. 주요 문제에는 PHP 응용 프로그램을 모니터링하고 보호하기위한 권장 도구가 포함 된 주입, 인증 파손 및 XSS가 포함됩니다.

PHP XSS 예방 : XSS로부터 보호하는 방법.PHP XSS 예방 : XSS로부터 보호하는 방법.Mar 26, 2025 pm 04:12 PM

이 기사는 PHP의 XSS 공격을 방지하기위한 전략, 입력 소독, 출력 인코딩 및 보안 향상 라이브러리 및 프레임 워크 사용에 중점을 둔 전략에 대해 설명합니다.

PHP 인터페이스 대 추상 클래스 : 각각을 사용할 때.PHP 인터페이스 대 추상 클래스 : 각각을 사용할 때.Mar 26, 2025 pm 04:11 PM

이 기사는 각각의 사용시기에 중점을 둔 PHP의 인터페이스 및 추상 클래스 사용에 대해 설명합니다. 인터페이스는 관련없는 클래스 및 다중 상속에 적합한 구현없이 계약을 정의합니다. 초록 클래스는 일반적인 기능을 제공합니다

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 채팅 명령 및 사용 방법
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

Dreamweaver Mac版

Dreamweaver Mac版

시각적 웹 개발 도구

PhpStorm 맥 버전

PhpStorm 맥 버전

최신(2018.2.1) 전문 PHP 통합 개발 도구

SublimeText3 영어 버전

SublimeText3 영어 버전

권장 사항: Win 버전, 코드 프롬프트 지원!

DVWA

DVWA

DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

mPDF

mPDF

mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.