현재 위치: > 최신 기사 목록> 액세스 실패를 피하기 위해 fpassthru 기능을 사용할 때 파일 권한 문제를 처리하는 방법은 무엇입니까?

액세스 실패를 피하기 위해 fpassthru 기능을 사용할 때 파일 권한 문제를 처리하는 방법은 무엇입니까?

gitbox 2025-08-25

PHP에서 fpassthru () 함수는 표준 출력 스트림에 직접 파일 포인터 (Resource)가 가리키는 컨텐츠를 출력하는 데 사용됩니다. 이 기능은 일반적으로 다운로드 또는 디스플레이를 위해 파일 내용 (예 : 그림, 오디오 또는 텍스트 파일)을 브라우저로 전달하는 데 사용됩니다. 그러나 강력한 기능에도 불구하고 파일 권한이 제대로 설정되지 않으면 파일 액세스가 실패 또는 권한 오류에 대한 액세스를 초래할 수 있으므로 fpassthru ()가 정상적으로 실행되는 것을 방지 할 수 있습니다. 이 기사는이 문제를 해결하는 방법을 살펴보고 fpassthru ()가 원활하게 작동 할 수 있도록합니다.

1. 파일 권한 기본 사항

Unix/Linux 시스템에서 각 파일과 디렉토리에는 파일을 읽거나 쓰거나 실행할 수있는 사용자 또는 사용자 그룹을 결정하는 권한이 다릅니다. 일반적인 권한 설정은 다음과 같습니다.

  • r (read) : 파일의 내용을 읽을 수 있음을 의미합니다.

  • w (쓰기) : 파일 내용을 수정할 수 있음을 의미합니다.

  • x (execute) : 실행 파일을 의미합니다 (스크립트 및 프로그램 파일에 중요 함).

파일 권한은 일반적으로 ChMOD 명령을 통해 설정된 다른 사용자에 대해 다른 컨트롤을 수행하도록 설정할 수도 있습니다. Apache와 같은 웹 서버에서 실행되는 PHP 스크립트의 경우 파일을 읽을 수있는 적절한 권한이 있는지 확인하는 것이 중요합니다.

2. fpassthru () 권한 요구 사항

fpassthru () 함수는 파일 내용을 읽고 파일 포인터를 통해 출력합니다. 파일 권한이 제대로 설정되지 않으면 PHP가 파일에 액세스하지 못하여 파일 읽기 실패를 초래할 수 있습니다. 일반적인 오류는 다음과 같습니다.

  • 파일이 존재하지 않습니다 . 파일 경로가 올바르지 않거나 파일이 존재하지 않습니다.

  • 불충분 한 권한 : PHP 스크립트를 실행하는 사용자는 파일을 읽을 수있는 권한이 없습니다.

  • 실행 불가능한 파일 : 일부 파일에는 실행 권한이 필요할 수 있으며 적절한 실행 권한 없이는 읽을 수 없습니다.

3. 파일 권한을 다루는 방법

fpassthru () 함수가 파일 컨텐츠를 성공적으로 읽고 출력 할 수 있도록하려면 파일의 권한을 올바르게 설정해야합니다. 몇 가지 일반적인 솔루션은 다음과 같습니다.

(1) 파일 경로가 올바른지 확인하십시오

fpassthru ()를 사용하기 전에 먼저 파일 경로가 올바른지 확인해야합니다. 파일 경로가 잘못된 경우 PHP는 대상 파일을 찾을 수 없으며 자연스럽게 액세스 할 수 없습니다. 다음 코드를 통해 파일이 존재하는지 확인할 수 있습니다.

 <span><span><span class="hljs-variable">$file</span></span><span> = </span><span><span class="hljs-string">'/path/to/your/file.txt'</span></span><span>;

</span><span><span class="hljs-keyword">if</span></span><span> (!</span><span><span class="hljs-title function_ invoke__">file_exists</span></span><span>(</span><span><span class="hljs-variable">$file</span></span><span>)) {
    </span><span><span class="hljs-keyword">die</span></span><span>(</span><span><span class="hljs-string">'파일이 존재하지 않습니다'</span></span><span>);
}
</span></span>

(2) 파일을 읽을 수 있는지 확인하십시오

PHP 스크립트는 파일에 대한 읽기 권한이 필요합니다. CHMOD 명령을 사용하여 파일의 권한을 수정하여 PHP 프로세스를 읽을 수 있도록합니다. 일반적으로 644로 설정할 수 있습니다 (즉, 사용자는 읽기 및 쓰기 권한이있는 반면 다른 사람은 읽기 권한 만 가지고 있습니다).

 <span><span><span class="hljs-built_in">chmod</span></span><span> 644 /path/to/your/file.txt
</span></span>

파일이 특정 사용자 (예 : 웹 서버 사용자 www-data )에 속하는 경우 chown 명령을 사용하여 파일의 소유자를 수정할 수 있습니다.

 <span><span><span class="hljs-built_in">chown</span></span><span> www-data:www-data /path/to/your/file.txt
</span></span>

(3) iS_Readable ()을 사용하여 파일 권한을 확인하십시오

fpassthru ()를 실행하기 전에 is_readable () 함수를 사용하여 파일을 읽을 수 있는지 확인할 수 있습니다.

 <span><span><span class="hljs-keyword">if</span></span><span> (</span><span><span class="hljs-title function_ invoke__">is_readable</span></span><span>(</span><span><span class="hljs-variable">$file</span></span><span>)) {
    </span><span><span class="hljs-variable">$handle</span></span><span> = </span><span><span class="hljs-title function_ invoke__">fopen</span></span><span>(</span><span><span class="hljs-variable">$file</span></span><span>, </span><span><span class="hljs-string">'rb'</span></span><span>);
    </span><span><span class="hljs-title function_ invoke__">fpassthru</span></span><span>(</span><span><span class="hljs-variable">$handle</span></span><span>);
    </span><span><span class="hljs-title function_ invoke__">fclose</span></span><span>(</span><span><span class="hljs-variable">$handle</span></span><span>);
} </span><span><span class="hljs-keyword">else</span></span><span> {
    </span><span><span class="hljs-keyword">die</span></span><span>(</span><span><span class="hljs-string">'파일을 읽을 수 없습니다'</span></span><span>);
}
</span></span>

(4) 웹 서버 사용자에게 권한이 있는지 확인하십시오

웹 서버 (예 : Apache 또는 Nginx)는 일반적으로 특정 사용자를 사용하여 PHP 스크립트를 실행합니다. 사용자 이름은 PS Aux를 통해 볼 수 있습니다 | grep apache 또는 ps aux | grep nginx 명령. 사용자가 파일에 적절한 권한이 있는지 확인하십시오. 이 사용자는 파일 권한을 읽을 수 있도록 설정할 수 있습니다.

 <span><span><span class="hljs-built_in">chmod</span></span><span> 755 /path/to/your/file.txt
</span></span>

(5) 루트 사용자를 사용하여 웹 서버를 실행하지 마십시오

서버에서 웹 서비스를 실행할 때는 루트 사용자 사용을 피해야합니다. PHP 스크립트가 루트 사용자로 실행되면 허가 누출 위험이 발생할 수 있습니다. 적절한 사용자 그룹 및 권한을 설정하면 PHP 스크립트가 최소한의 권한으로 실행되고 보안 취약점을 피할 수 있습니다.

(6) 디렉토리 권한 처리

파일이있는 디렉토리에 읽기 권한이없는 경우 PHP는 파일을 열 수 없습니다. 따라서 파일 자체 외에도 디렉토리 권한도 읽을 수 있도록 설정해야합니다 (일반적으로 755로 설정).

 <span><span><span class="hljs-built_in">chmod</span></span><span> 755 /path/to/your/directory
</span></span>

4. 큰 파일의 권한 문제를 처리합니다

큰 파일을 처리 할 때, fpassthru () 함수는 특히 파일을 메모리에 완전히로드 할 수없는 경우 몇 가지 제한 사항에 직면 할 수 있습니다. PHP 구성의 메모리 제한이 충분히 높고 파일에 올바른 권한이 있는지 확인하십시오.

php.ini 에서 다음 설정을 조정할 수 있습니다.

 <span><span><span class="hljs-attr">memory_limit</span></span><span> = </span><span><span class="hljs-number">256</span></span><span>M   </span><span><span class="hljs-comment">; 메모리 제한을 늘리십시오</span></span><span>
</span><span><span class="hljs-attr">max_execution_time</span></span><span> = </span><span><span class="hljs-number">300</span></span><span>   </span><span><span class="hljs-comment">; 최대 실행 시간을 설정하십시오</span></span><span>
</span></span>

5 안전 고려 사항

fpassthru ()를 사용하여 파일을 처리 할 때는 항상 파일 경로가 신뢰할 수 있는지 확인하십시오. 사용자가 경로 이동 공격 (디렉토리 트래버스)을 피하기 위해 엄격하게 검증되지 않은 파일 경로를 입력하도록 허용하지 마십시오. 보안 위험을 줄이기 위해 명확하지 않은 파일 경로 또는 사용자 입력을 피해야합니다.

 <span><span><span class="hljs-variable">$file</span></span><span> = </span><span><span class="hljs-title function_ invoke__">realpath</span></span><span>(</span><span><span class="hljs-string">'/path/to/your/file.txt'</span></span><span>);
</span><span><span class="hljs-keyword">if</span></span><span> (</span><span><span class="hljs-title function_ invoke__">strpos</span></span><span>(</span><span><span class="hljs-variable">$file</span></span><span>, </span><span><span class="hljs-string">'/path/to/your/'</span></span><span>) !== </span><span><span class="hljs-number">0</span></span><span>) {
    </span><span><span class="hljs-keyword">die</span></span><span>(</span><span><span class="hljs-string">'불법 파일 액세스'</span></span><span>);
}
</span></span>

6. 요약

fpassthru () 함수를 사용하는 경우 파일 권한 설정이 중요합니다. 파일이 존재하고 읽을 수 있으며 PHP 스크립트에 이러한 파일에 액세스 할 수있는 충분한 권한이 있는지 확인하십시오. 파일 경로를 확인하고 권한 조정 및 PHP 환경을 구성하면 파일 액세스 실패를 효과적으로 피할 수 있습니다. 또한 보안에주의를 기울이고 안전하지 않은 경로 입력을 피하십시오.

이러한 측정을 통해 PHP의 fpassthru () 기능이 파일 컨텐츠를 원활하게 읽고 출력하여 사용자에게 더 부드러운 경험을 제공 할 수 있습니다.