>  기사  >  백엔드 개발  >  PHP7.0에서 파일 업로드 처리를 수행하는 방법은 무엇입니까?

PHP7.0에서 파일 업로드 처리를 수행하는 방법은 무엇입니까?

WBOY
WBOY원래의
2023-05-26 08:21:111104검색

인터넷 시대의 발달과 함께 웹사이트 개발에 있어서 파일 업로드는 매우 중요한 역할을 담당하고 있습니다. 사용자가 자신의 아바타, 사진 또는 기타 파일을 업로드해야 하는 경우 웹사이트는 업로드된 파일을 처리해야 합니다. PHP7.0에서는 파일 업로드를 처리하는 방식이 이전 버전과 약간 다릅니다. 이 기사에서는 PHP7.0에서 파일 업로드 처리를 수행하는 방법을 소개합니다.

1. 파일 업로드를 위한 HTML 형식

HTML 형식에서는 파일 업로드에 3525558f8f338d4ea90ebf22e5cde2bc 태그가 사용됩니다. enctype 속성을 "multipart/form-data"로 설정해야 하며 제출 방법은 POST 방법입니다. 예:

<form action="upload.php" method="POST" enctype="multipart/form-data">
  <input type="file" name="file">
  <input type="submit" value="上传文件">
</form>

2. PHP는 업로드된 파일을 처리합니다.

PHP에서는 $_FILES 배열을 사용하여 업로드된 파일을 처리합니다. 파일. 사용자가 파일을 선택하고 양식을 제출하면 $_FILES 배열에 업로드된 파일에 대한 정보가 포함됩니다. 예:

$_FILES['file']['name'] // 文件名
$_FILES['file']['type'] // 文件类型
$_FILES['file']['size'] // 文件大小
$_FILES['file']['tmp_name'] // 临时文件名
$_FILES['file']['error'] // 错误代码

임시 파일 이름은 업로드가 완료된 후 업로드된 파일의 내용을 읽는 데 사용됩니다. 다음으로 이 정보를 사용하여 파일을 업로드하는 방법을 살펴보겠습니다.

3. 파일을 업로드하고 서버에 저장합니다

move_uploaded_file() 함수를 사용하여 업로드된 파일을 임시 폴더에서 지정된 대상 폴더로 이동할 수 있습니다. 예:

$target_dir = "uploads/"; // 目标文件夹
$target_file = $target_dir . basename($_FILES["file"]["name"]); // 目标文件路径
if (move_uploaded_file($_FILES["file"]["tmp_name"], $target_file)) {
    echo "文件上传成功";
} else {
    echo "文件上传失败";
}

업로드된 파일을 받기 전에 대상 폴더가 존재하는지 확인해야 합니다. 그렇지 않으면 move_uploaded_file() 함수가 실패합니다.

4. 업로드된 파일 처리 오류

파일 업로드 시 합의된 크기를 초과하는 파일, 업로드 실패 등 일부 오류가 발생할 수 있습니다. $_FILES 배열의 error 속성을 사용하여 이러한 오류를 처리할 수 있습니다.

switch ($_FILES["file"]["error"]) {
    case UPLOAD_ERR_OK: // 成功
        break;
    case UPLOAD_ERR_INI_SIZE: // 上传的文件超过了php.ini中的最大约束大小
    case UPLOAD_ERR_FORM_SIZE: // 上传的文件超过了HTML表单中的最大约束大小
        echo "文件太大";
        break;
    case UPLOAD_ERR_PARTIAL: // 文件只有部分被上传
        echo "文件上传失败";
        break;
    case UPLOAD_ERR_NO_FILE: // 没有文件被上传
        echo "请选择文件";
        break;
    case UPLOAD_ERR_NO_TMP_DIR: // 服务器未配置临时目录
    case UPLOAD_ERR_CANT_WRITE: // 无法将文件写入磁盘
    case UPLOAD_ERR_EXTENSION: // 文件不能通过PHP扩展上传
        echo "文件上传失败";
        break;
}

5. 업로드된 파일의 종류와 크기를 확인하세요

파일의 불법 업로드를 방지하기 위해 업로드된 파일의 종류와 크기도 확인해야 합니다. 예를 들어, 이미지 유형의 파일만 업로드가 허용되는 경우 getimagesize() 함수를 사용하여 파일 유형을 결정할 수 있습니다.

$allowed_types = array(IMAGETYPE_PNG, IMAGETYPE_JPEG, IMAGETYPE_GIF);
$type = exif_imagetype($_FILES["file"]["tmp_name"]);
if (!in_array($type, $allowed_types)) {
    echo "请选择正确的图像类型";
}

동시에 파일 크기를 확인해야 합니다. 예를 들어, PHP의 filesize() 함수를 사용할 수 있습니다.

$max_size = 2 * 1024 * 1024; // 允许上传最大文件大小为2MB
if (filesize($_FILES["file"]["tmp_name"]) > $max_size) {
    echo "文件太大";
}

6. 요약

PHP7.0에서는 파일 업로드 처리가 더 안전하고 간편해집니다. $_FILES 배열을 통해 업로드된 파일 정보를 얻을 수 있으며, move_uploaded_file() 함수를 사용하여 파일을 서버에 저장하고 업로드된 파일의 형식과 크기를 확인하여 업로드된 파일이 안전하고 신뢰할 수 있는지 확인할 수 있습니다.

위 내용은 PHP7.0에서 파일 업로드 처리를 수행하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.