ホームページ >バックエンド開発 >PHPチュートリアル >PHPにおけるファイルアップロードの原理とエラー報告の理由を詳しく解説
アップロードの原則と構成
1.1 原則
クライアントのファイルをサーバーにアップロードし、サーバー側のファイル(一時ファイル)を指定されたディレクトリに移動します。
1.2 クライアント設定
必須: フォームページ (アップロードファイルを選択);
具体的に: 送信方法は POST、enctype="multipart/form-data"属性を追加、両方とも必須です (ただし、両方あります)利点と欠点は、アップロード方法とアップロードされたファイルの呼び出しも制限します。これについては後述します)
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>Insert title here</title> </head> <body> <form action="doAction.php" method="post" enctype="multipart/form-data"> 请选择您要上传的文件: <input type="file" name="myFile" /><br/> <input type="submit" value="上传"/> </form> <?php ?> </body> </html>
最初はフォーム ページです (フロントエンドの問題は自動的に無視してください...)。 ; という形式の属性 また、入力には type="file" が使用されます (PHP の強力な拡張などを反映しています)。
次にdoAction
<?php //$_FILES:文件上传变量 //print_r($_FILES); $filename=$_FILES['myFile']['name']; $type=$_FILES['myFile']['type']; $tmp_name=$_FILES['myFile']['tmp_name']; $size=$_FILES['myFile']['size']; $error=$_FILES['myFile']['error']; //将服务器上的临时文件移动到指定位置 //方法一move_upload_file($tmp_name,$destination) //move_uploaded_file($tmp_name, "uploads/".$filename);//文件夹应提前建立好,不然报错 //方法二copy($src,$des) //以上两个函数都是成功返回真,否则返回false //copy($tmp_name, "copies/".$filename); //注意,不能两个方法都对临时文件进行操作,临时文件似乎操作完就没了,我们试试反过来 copy($tmp_name, "copies/".$filename); move_uploaded_file($tmp_name, "uploads/".$filename); //能够实现,说明move那个函数基本上相当于剪切;copy就是copy,临时文件还在 //另外,错误信息也是不一样的,遇到错误可以查看或者直接报告给用户 if ($error==0) { echo "上传成功!"; }else{ switch ($error){ case 1: echo "超过了上传文件的最大值,请上传2M以下文件"; break; case 2: echo "上传文件过多,请一次上传20个及以下文件!"; break; case 3: echo "文件并未完全上传,请再次尝试!"; break; case 4: echo "未选择上传文件!"; break; case 5: echo "上传文件为0"; break; } }
まずprint_r($_FILES)の情報を見てください
Array ( [myFile] => Array ( [name] => 简历.doc [type] => application/msword [tmp_name] => D:\wamp\tmp\php1D78.tmp [error] => 0 [size] => 75776 ) )
つまり、得られるものは二次元配列です。 ;
これは基本的に、冗長ではなく一目で理解できるものです。重要なポイントは 2 つあります。 tmp_name 一時ファイル名 (コード名。後で使用できます)。
次に doAction の最後の部分を見て、エラー メッセージを使用してユーザーにフィードバックします。説明する必要があるのは、エラーが報告される理由とエラー メッセージの内容です。
1.3 エラー レポートについて
--エラーの理由
基本的に、ファイルをアップロードするためのサーバーの構成を超えているか、準拠していません。次に、サーバー側の構成があります。どれですか?
まず、私たちが使用したものをアップロードすることを検討してください? POST、アップロードします
それでは、php.ini で次の項目を探します:
file_upload:On
upload_tmp_dir=——一時ファイル保存ディレクトリ;
upload_max_filesize=2M
max_file_uploads=20——1 回のアップロードを許可ファイルの最大数 (上記との違いに注意してください。サイズがある場合は考慮しないでください)
post_max_size=8M - 投稿モードでデータを送信するための最大値
その他の関連する設定
max_exectuion_time=- 1 - プログラムがサーバー リソースを占有しないようにするための最大実行時間
max_input_time=60
max_input_nesting_level=64 - 入力ネストの深さ
memory_limit=128M - 単一スレッドの最大独立メモリ使用量
重要なのはリソースの構成です。
--エラー番号
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; ファイルはアップロードされませんでした。
注: このエラー メッセージは、アップロードの最初のステップ、つまり一時フォルダーにアップロードするときの情報であり、移動またはコピーするときの情報ではありません。
以上がPHPにおけるファイルアップロードの原理とエラー報告の理由を詳しく解説の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。