ホームページ >バックエンド開発 >PHPチュートリアル >PHPでの$_FILESの使い方と注意点_PHPチュートリアル
$_FILES: HTTP POST ファイルのアップロード経由でスクリプトに送信される変数。古い配列 $HTTP_POST_FILES 配列に似ています (まだ有効ですが、非推奨です) 詳細については、POST メソッドのアップロードを参照してください
$_FILES 配列の内容は次のとおりです:
$_FILES['myFile']['name'] クライアント ファイルの元の名前
$_FILES['myFile']['type'] ファイルの MIME タイプ。ブラウザは、「image/gif」などのこの情報のサポートを提供する必要があります
$_FILES['myFile']['size'] アップロードされたファイルのサイズ (バイト単位)
$_FILES['myFile']['tmp_name'] ファイルのアップロード後にサーバーに保存される一時ファイル名。通常は php.ini の Upload_tmp_dir で指定できますが、設定することはできません。 putenv() 関数を使用します。
$_FILES['myFile']['error'] ファイルのアップロードに関連するエラー コード ['error'] は PHP 4.2.0 バージョンで追加されました。以下はその説明です: (PHP3.0 では、これからは定数になります)UPLOAD_ERR_OK 値: 0; エラーは発生せず、ファイルは正常にアップロードされました
UPLOAD_ERR_INI_SIZE 値: 1; アップロードされたファイルは php.ini の Upload_max_filesize オプションで制限された値を超えています
UPLOAD_ERR_FORM_SIZE 値: 2; アップロードされたファイルのサイズが HTML フォームの MAX_FILE_SIZE オプションで指定された値を超えています
UPLOAD_ERR_PARTIAL 値: 3; ファイルの一部のみがアップロードされました
UPLOAD_ERR_NO_FILE 値: 4; ファイルがアップロードされていません、値: 5; アップロードされたファイルのサイズは 0 です
注:1.
ファイルはデフォルトで一時ディレクトリに保存されます。それ以外の場合は、一時ディレクトリから削除する必要があります。つまり、アップロードが成功したかどうかに関係なく、スクリプトの実行後、一時ディレクトリ内のファイルは必ず削除されます。したがって、ファイルを削除する前に、PHP の copy() 関数を使用して別の場所にコピーする必要があります。この時点で、ファイルのアップロード プロセスは完了します。2.
PHP 4.1.0 より前では、この配列の名前は $HTTP_POST_FILES でしたが、これは $_FILES のような自動グローバル変数ではありません。 PHP 3 は $HTTP_POST_FILES 配列をサポートしていません。3.
フォームを使用してファイルをアップロードする場合は、属性 content enctype="multipart/form-data" を必ず追加してください。追加しないと、$_FILES[filename] を使用してファイル情報を取得するときに例外が報告されます。
コードをコピーします