찾다
백엔드 개발PHP 문제PHP에서 파일 업로드 기능을 구현하는 방법

PHP에서 파일 업로드 기능을 구현하는 방법

PHP에서 파일 업로드를 구현하는 방법

1. 양식 부분

을 사용하면 HTML 양식 선언에 업로드 속성을 추가해야 합니다.

enctype = 'multipart/form-data'

메소드 양식은 POST여야 합니다.

양식 옵션 MAX_FILE_SIZE 숨겨진 필드는 업로드된 파일의 크기를 제한하는 데 사용되며 파일 양식 요소 앞에 바이트 단위로 배치되어야 합니다.

코드는 다음과 같습니다.

<form enctype=&#39;multipart/form-data&#39; id=&#39;aa&#39; name=&#39;aaa&#39; method=&#39;post&#39; action=&#39;xxx.php&#39;> 
<input type=&#39;hidden&#39; name=&#39;MAX_FILE_SIZE&#39; value=&#39;2621114&#39; /> 
<input name=&#39;upload_file&#39; type=&#39;file&#39; /> 
</form>

관련 권장 사항: "PHP 시작하기 튜토리얼"

2. 업로드된 파일 처리

업로드할 때 PHP는 파일에 대한 일련의 정보를 수신합니다. $_FILES에서 발견되었습니다. 슈퍼 전역 배열에서 발견되었습니다.

예: 양식의 파일 입력 상자 이름이 upload_file이면 파일에 대한 모든 정보가 $_FILES['upload_file'] 배열에 포함됩니다.

예: 고객이 "aaa.jpg" 이미지 배열 값을 다음과 같이 업로드했습니다.

name "p5pp.jpg" 업로드 시 파일 이름

type "image/jpeg" 파일 형식

tmp_name "/ tmp/phpjksdf "서버 측 임시 파일 이름

error 업로드 오류의 반환 값

size 2045 파일의 실제 크기

위 배열의 오류는 다음과 같이 다른 상수 값을 반환합니다.

UPLOAD_ERR_OK 오류가 발생하지 않았습니다. 파일이 성공적으로 업로드되었습니다.

UPLOAD_ERR_INI_SIZE 파일 크기가 PHP.INI의 upload_max_filesize 옵션 값을 초과했습니다.

UPLOAD_ERR_FORM_SIZE 업로드된 파일의 크기가 HTML 형식의 MAX_FILE_SIZE 옵션 값을 초과했습니다. 프로그램에서 $FILES ['up_file']['size'] 형식을 확인하여 처리할 수 있습니다.

UPLOAD_ERR_PARTIAL 파일의 일부만 업로드되었습니다.

UPLOAD_ERR_NO_FILE 사용자가 파일 업로드를 제공하지 않았습니다.

포스트의 구체적인 예 업로드 처리:

코드는 다음과 같습니다.

if(!move_uploaded_file($_FILES[&#39;f&#39;][&#39;tmp_name&#39;],"uploads/".$_FILES[&#39;f&#39;][&#39;name&#39;].".jpg")){ 
echo "error"; 
}

기능:

move_uploaded_file은 업로드된 임시 파일을 지정된 디렉터리로 이동합니다.

예:

move_uploaded_file('임시 파일 이름','지정된 파일 경로')

is_uploaded_file은 http Post 파일을 통해 업로드되는지 여부를 결정합니다.

예:

코드는 다음과 같습니다.

if(!is_uploaded_file($_FILES[&#39;f&#39;][&#39;tmp_name&#39;])){ 
echo &#39;非法&#39;; 
}

3. 관련 매개변수

PHP 업로드용으로 설계된 php.ini의 매개변수:

file_uploads 여부 파일 업로드를 허용합니다. 기본값은 ON입니다.

upload_tmp_dir은 파일 업로드를 위한 임시 디렉터리입니다. 지정하지 않으면 시스템 기본 위치가 사용됩니다.

upload_max_filesize 업로드가 허용되는 최대 파일 크기이며 기본값은 2M입니다.

post_max_size는 POST 메서드를 사용하여 양식 제출 시 PHP가 허용할 수 있는 최대 데이터 양을 제어합니다. PHP 파일을 사용하여 업로드하려면 이 값을 upload_max_filesize보다 크게 변경해야 합니다.

max_input_time은 POST/GET/PUT 메서드를 통해 데이터를 수락하는 시간을 초 단위로 제한합니다.

memory_limit 대량의 시스템 메모리를 사용하는 스크립트 실행을 방지하기 위해 PHP에서는 메모리 사용 제한을 정의할 수 있습니다. 단일 스크립트 프로그램이 사용할 수 있는 최대 메모리 용량을 지정하려면 이 매개변수를 설정합니다. 이 용량은 post_max_size 값보다 적절하게 커야 합니다.

max_execution_time은 스크립트를 강제로 종료하기 전에 PHP가 스크립트가 완료될 때까지 기다리는 시간(초)을 설정하는 데 사용됩니다. 이 두 번째 옵션은 무한 루프 스크립트를 제한할 수 있지만 이 기능은 장기간 합법적인 활동(예: 대용량 파일 업로드)이 있을 때 작업이 실패하도록 할 수도 있습니다. 이 경우 이 변수를 늘리는 것을 고려해야 합니다.

4. 다중 파일 업로드 고려

$_FILES 배열을 사용하면 여러 파일을 쉽게 업로드할 수 있습니다. $_FILES 배열은 클라이언트 양식의 모든 파일 필드 내용을 얻을 수 있으므로 동일한 양식으로 업로드된 모든 파일을 얻을 수 있습니다.

5. 업로드 메모리 제한 돌파

방법 1:

php.ini의 memory_limit 값을 64M과 같은 더 큰 값으로 수정합니다.

방법 2:

Apache Rewrite 방법을 사용하여 동적으로 수정합니다. memory_limit 값. 먼저 .htaccess 파일을 생성하고 파일 업로드 프로그램의 현재 디렉터리에 저장합니다.

코드는 다음과 같습니다:

php_value memory_limit 100M 
php_value post_max_size 30M 
php_value upload_max_filesize 30M 
php_value max_execution_time 300 
php_value max_input_tim 300 
php_value display_errors On

위 내용은 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를 무료로 생성하십시오.

뜨거운 도구

MinGW - Windows용 미니멀리스트 GNU

MinGW - Windows용 미니멀리스트 GNU

이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

WebStorm Mac 버전

WebStorm Mac 버전

유용한 JavaScript 개발 도구

Dreamweaver Mac版

Dreamweaver Mac版

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)