ホームページ  >  記事  >  バックエンド開発  >  PHP7.0でファイルアップロード処理を行うにはどうすればよいですか?

PHP7.0でファイルアップロード処理を行うにはどうすればよいですか?

WBOY
WBOYオリジナル
2023-05-26 08:21:111106ブラウズ

インターネット時代の発展に伴い、ファイルのアップロードは Web サイト開発において非常に重要な役割を果たしています。ユーザーが自分のアバター、写真、その他のファイルをアップロードする必要がある場合、Web サイトはアップロードされたファイルを処理する必要があります。 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 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。