ホームページ  >  記事  >  バックエンド開発  >  PHPにおけるファイルアップロードの原理とエラー報告の理由を詳しく解説

PHPにおけるファイルアップロードの原理とエラー報告の理由を詳しく解説

伊谢尔伦
伊谢尔伦オリジナル
2017-06-27 14:08:132179ブラウズ

アップロードの原則と構成

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[&#39;myFile&#39;][&#39;name&#39;];
$type=$_FILES[&#39;myFile&#39;][&#39;type&#39;];
$tmp_name=$_FILES[&#39;myFile&#39;][&#39;tmp_name&#39;];
$size=$_FILES[&#39;myFile&#39;][&#39;size&#39;];
$error=$_FILES[&#39;myFile&#39;][&#39;error&#39;];
//将服务器上的临时文件移动到指定位置
//方法一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 サイトの他の関連記事を参照してください。

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