>백엔드 개발 >PHP 문제 >PHP에서 여러 파일 업로드 형식을 지정하는 방법

PHP에서 여러 파일 업로드 형식을 지정하는 방법

醉折花枝作酒筹
醉折花枝作酒筹앞으로
2021-05-10 17:19:452184검색

이 글에서는 PHP에서 여러 파일 업로드 형식을 지정하는 방법을 소개합니다. 도움이 필요한 친구들이 모두 참고할 수 있기를 바랍니다.

PHP에서 여러 파일 업로드 형식을 지정하는 방법

추천: "2021 PHP 면접 질문 요약(모음)" "php 비디오 튜토리얼"

파일 업로드는 모든 웹 애플리케이션에서 가장 일반적인 기능이며 PHP는 이 기능을 구현하는 데에도 매우 유용합니다. 매우 간단합니다. 프런트 엔드에서 양식의 enctype 값을 multipart/form-data로 설정하면 $_FILES를 통해 양식의 파일 제어 내용을 가져올 수 있습니다.

동시에 파일 컨트롤의 이름을 []를 사용하여 배열로 작성할 수도 있으므로 업로드된 여러 파일을 받을 수 있습니다. 예를 들어 테스트에는 다음 형식이 사용됩니다.

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <form action="" enctype="multipart/form-data" method="post">

    myfile1:<input type="file" name="myfile[]"/><br/>
    myfile2:<input type="file" name="myfile[a][]"/><br/>
    myfile3:<input type="file" name="myfile[a][b][]"/><br/>
    myfile4:<input type="file" name="myfile[c][]"/><br/>
    myfile5:<input type="file" name="myfile[]"/><br/>
    myfile6:<input type="file" name="myfile[][]"/><br/>
    <br/>
    newfile1:<input type="file" name="newfile[][]"/><br/>
    newfile2:<input type="file" name="newfile[s]"/><br/>

    singlefile: <input type="file" name="singlefile"/><br/>
        <input type="submit" value="submit"/>
    </form>
</body>
</html>

총 9개의 파일 컨트롤이 있는데, 그 중 myfile과 newfile은 모두 배열 형식 형식 이름이고, Singlefile은 별도의 형식 이름입니다. 먼저 $_FILES에서 얻은 내용을 간략하게 살펴보겠습니다.

print_r($_FILES);

Array
(
    [myfile] => Array
        (
            [name] => Array
                (
                    [0] => 2591d8b3eee018a0a84f671933ab6c74.png
                    [a] => Array
                        (
                            [0] => 12711584942474_.pic_hd 1.jpg
                            [b] => Array
                                (
                                    [0] => 12721584942474_.pic_hd 1.jpg
                                )

                        )

                    [c] => Array
                        (
                            [0] => 12731584942474_.pic_hd.jpg
                        )

                    [1] => background1.jpg
                    [2] => Array
                        (
                            [0] => adliu_pip_data.xlsx
                        )

                )

            [type] => Array
                (
                    [0] => image/png
                    [a] => Array
                        (
                            [0] => image/jpeg
                            [b] => Array
                                (
                                    [0] => image/jpeg
                                )

                        )

                    [c] => Array
                        (
                            [0] => image/jpeg
                        )

                    [1] => image/jpeg
                    [2] => Array
                        (
                            [0] => application/vnd.openxmlformats-officedocument.spreadsheetml.sheet
                        )

                )

            [tmp_name] => Array
                (
                    [0] => /private/var/folders/wj/t2z1cfhs0m9gq48krm8nc0vm0000gn/T/phphD88ZY
                    [a] => Array
                        (
                            [0] => /private/var/folders/wj/t2z1cfhs0m9gq48krm8nc0vm0000gn/T/phpNY8MzY
                            [b] => Array
                                (
                                    [0] => /private/var/folders/wj/t2z1cfhs0m9gq48krm8nc0vm0000gn/T/php3MX5tk
                                )

                        )

                    [c] => Array
                        (
                            [0] => /private/var/folders/wj/t2z1cfhs0m9gq48krm8nc0vm0000gn/T/phpjgrHMj
                        )

                    [1] => /private/var/folders/wj/t2z1cfhs0m9gq48krm8nc0vm0000gn/T/phppXRtnc
                    [2] => Array
                        (
                            [0] => /private/var/folders/wj/t2z1cfhs0m9gq48krm8nc0vm0000gn/T/phpekSY1M
                        )

                )

            [error] => Array
                (
                    [0] => 0
                    [a] => Array
                        (
                            [0] => 0
                            [b] => Array
                                (
                                    [0] => 0
                                )

                        )

                    [c] => Array
                        (
                            [0] => 0
                        )

                    [1] => 0
                    [2] => Array
                        (
                            [0] => 0
                        )

                )

            [size] => Array
                (
                    [0] => 4973
                    [a] => Array
                        (
                            [0] => 3007
                            [b] => Array
                                (
                                    [0] => 1156
                                )

                        )

                    [c] => Array
                        (
                            [0] => 6068
                        )

                    [1] => 393194
                    [2] => Array
                        (
                            [0] => 36714
                        )

                )

        )

    [newfile] => Array
        (
            [name] => Array
                (
                    [0] => Array
                        (
                            [0] => 数据列表 (2).xlsx
                        )

                    [s] => background1.jpg
                )

            [type] => Array
                (
                    [0] => Array
                        (
                            [0] => application/vnd.openxmlformats-officedocument.spreadsheetml.sheet
                        )

                    [s] => image/jpeg
                )

            [tmp_name] => Array
                (
                    [0] => Array
                        (
                            [0] => /private/var/folders/wj/t2z1cfhs0m9gq48krm8nc0vm0000gn/T/phplSsRfM
                        )

                    [s] => /private/var/folders/wj/t2z1cfhs0m9gq48krm8nc0vm0000gn/T/phpuQAvRb
                )

            [error] => Array
                (
                    [0] => Array
                        (
                            [0] => 0
                        )

                    [s] => 0
                )

            [size] => Array
                (
                    [0] => Array
                        (
                            [0] => 77032
                        )

                    [s] => 393194
                )

        )

    [singlefile] => Array
        (
            [name] => timg (8).jpeg
            [type] => image/jpeg
            [tmp_name] => /private/var/folders/wj/t2z1cfhs0m9gq48krm8nc0vm0000gn/T/phpxtSQ4J
            [error] => 0
            [size] => 10273
        )

)

무슨 문제가 있나요?

$_FILE[&#39;singlefile&#39;][&#39;name&#39;];
$_FILE[&#39;singlefile&#39;][&#39;type&#39;];
$_FILE[&#39;singlefile&#39;][&#39;tmp_name&#39;];
$_FILE[&#39;singlefile&#39;][&#39;error&#39;];
$_FILE[&#39;singlefile&#39;][&#39;error&#39;];

$_FILE[&#39;myfile&#39;][&#39;name&#39;][&#39;a&#39;][&#39;b&#39;][0];
$_FILE[&#39;myfile&#39;][&#39;type&#39;][&#39;a&#39;][&#39;b&#39;][0];
$_FILE[&#39;myfile&#39;][&#39;tmp_name&#39;][&#39;a&#39;][&#39;b&#39;][0];
$_FILE[&#39;myfile&#39;][&#39;error&#39;][&#39;a&#39;][&#39;b&#39;][0];
$_FILE[&#39;myfile&#39;][&#39;error&#39;][&#39;a&#39;][&#39;b&#39;][0];

단일 형식은 해당 이름, 유형 및 기타 속성을 포함하는 키 이름으로 단일 파일을 사용하는 배열입니다. 이는 매우 간단하고 명확하지만 배열 형태로 업로드되는 콘텐츠는 더 복잡합니다. 각 속성 아래에는 여러 값이 있으며 이러한 값은 중첩된 배열일 수도 있습니다.

예를 들어 myfile[a][b][]의 업로드된 파일 콘텐츠를 가져오려면 $_FILE['myfile']['name']['a']['b'를 전달해야 합니다. ][0 ], $_FILE['myfile']['type']['a']['b'][0] 관련 콘텐츠를 가져옵니다.

이건 별로 친숙하지 않아서 오늘의 주제는 이렇습니다. 이 내용을 단일 파일과 유사한 구조로 만들어 보겠습니다. 즉, 파일의 관련 내용이 이름 구조 아래에 모두 들어 있습니다. 예를 들어, myfile[a][b][]의 내용은 모두 $_FILE['myfile'][a][b][0] 아래에 있습니다.

$files = [];
// 开始数据格式化
foreach ($_FILES as $uploadKey => $uploadFiles) {
    // 需要将 $_FILES 中的五个字段都拿出来
    $files[$uploadKey] = formatUploadFiles($uploadFiles[&#39;name&#39;], $uploadFiles[&#39;type&#39;], $uploadFiles[&#39;tmp_name&#39;], $uploadFiles[&#39;error&#39;], $uploadFiles[&#39;size&#39;]);
}

// 格式化上传文件数组
function formatUploadFiles($fileNamesArray, $type, $tmp_name, $error, $size)
{
    $tmpFiles = [];
    // 文件名是否是数组,如果不是数组,就是单个文件上传
    if (is_array($fileNamesArray)) {
        // 数组形式上传
        foreach ($fileNamesArray as $idx => $fileName) {
            // 如果还是嵌套的数组,递归遍历接下来的内容
            if (is_array($fileName)) {
                $tmpFiles[$idx] = formatUploadFiles($fileName, $type[$idx] ?? [], $tmp_name[$idx] ?? [], $error[$idx] ?? [], $size[$idx] ?? []);
            } else {
                // 组合多维的格式化内容
                $tmpFiles[$idx] = [
                    &#39;name&#39; => $fileName,
                    &#39;type&#39; => $type[$idx] ?? &#39;&#39;,
                    &#39;tmp_name&#39; => $tmp_name[$idx] ?? &#39;&#39;,
                    &#39;error&#39; => $error[$idx] ?? &#39;&#39;,
                    &#39;size&#39; => $size[$idx] ?? &#39;&#39;,
                ];
            }
        }
    } else {
        // 组合单个的内容
        $tmpFiles = [
            &#39;name&#39; => $fileName,
            &#39;type&#39; => $type ?? &#39;&#39;,
            &#39;tmp_name&#39; => $tmp_name ?? &#39;&#39;,
            &#39;error&#39; => $error ?? &#39;&#39;,
            &#39;size&#39; => $size ?? &#39;&#39;,
        ];
    }

    return $tmpFiles;
}

print_r($files);

코드는 여전히 이해하기 매우 쉽습니다. 이는 깊은 순회와 동일한 재귀 기간을 통해 전체 $_FILES 디렉터리 트리를 순회합니다. 물론 이로 인해 성능 저하도 발생하므로 결국 루프 + 재귀 순회가 필요합니다. 하지만 다행히도 대부분의 경우 우리가 업로드하는 파일은 그다지 많지 않습니다. 하지만 반면에 미리 포맷하지 않으면 업로드된 콘텐츠를 모두 가져오려면 여전히 다층 또는 재귀 순회를 수행해야 합니다.

다음으로 형식화된 출력을 살펴보겠습니다.

Array
(
    [myfile] => Array
        (
            [0] => Array
                (
                    [name] => 2591d8b3eee018a0a84f671933ab6c74.png
                    [type] => image/png
                    [tmp_name] => /private/var/folders/wj/t2z1cfhs0m9gq48krm8nc0vm0000gn/T/phpV7A2yC
                    [error] => 0
                    [size] => 4973
                )

            [a] => Array
                (
                    [0] => Array
                        (
                            [name] => 12711584942474_.pic_hd 1.jpg
                            [type] => image/jpeg
                            [tmp_name] => /private/var/folders/wj/t2z1cfhs0m9gq48krm8nc0vm0000gn/T/php5q2d1Z
                            [error] => 0
                            [size] => 3007
                        )

                    [b] => Array
                        (
                            [0] => Array
                                (
                                    [name] => 12721584942474_.pic_hd 1.jpg
                                    [type] => image/jpeg
                                    [tmp_name] => /private/var/folders/wj/t2z1cfhs0m9gq48krm8nc0vm0000gn/T/phpdvv8No
                                    [error] => 0
                                    [size] => 1156
                                )

                        )

                )

            [c] => Array
                (
                    [0] => Array
                        (
                            [name] => 12731584942474_.pic_hd.jpg
                            [type] => image/jpeg
                            [tmp_name] => /private/var/folders/wj/t2z1cfhs0m9gq48krm8nc0vm0000gn/T/php9tfGmp
                            [error] => 0
                            [size] => 6068
                        )

                )

            [1] => Array
                (
                    [name] => background1.jpg
                    [type] => image/jpeg
                    [tmp_name] => /private/var/folders/wj/t2z1cfhs0m9gq48krm8nc0vm0000gn/T/phplUVpzA
                    [error] => 0
                    [size] => 393194
                )

            [2] => Array
                (
                    [0] => Array
                        (
                            [name] => adliu_pip_data.xlsx
                            [type] => application/vnd.openxmlformats-officedocument.spreadsheetml.sheet
                            [tmp_name] => /private/var/folders/wj/t2z1cfhs0m9gq48krm8nc0vm0000gn/T/phpNRtiaC
                            [error] => 0
                            [size] => 36714
                        )

                )

        )

    [newfile] => Array
        (
            [0] => Array
                (
                    [0] => Array
                        (
                            [name] => 数据列表 (2).xlsx
                            [type] => application/vnd.openxmlformats-officedocument.spreadsheetml.sheet
                            [tmp_name] => /private/var/folders/wj/t2z1cfhs0m9gq48krm8nc0vm0000gn/T/phpBLG7aG
                            [error] => 0
                            [size] => 77032
                        )

                )

            [s] => Array
                (
                    [name] => background1.jpg
                    [type] => image/jpeg
                    [tmp_name] => /private/var/folders/wj/t2z1cfhs0m9gq48krm8nc0vm0000gn/T/phpjyqCFY
                    [error] => 0
                    [size] => 393194
                )

        )

    [singlefile] => Array
        (
            [name] =>
            [type] => image/jpeg
            [tmp_name] => /private/var/folders/wj/t2z1cfhs0m9gq48krm8nc0vm0000gn/T/phpuYJXiE
            [error] => 0
            [size] => 10273
        )

)

위의 원본 $_FILES보다 훨씬 더 명확하고 명확합니까? 이번에는 myfile[a][b][]의 모든 내용이 필요한 경우 다음 방법을 사용하여 쉽게 얻을 수 있습니다:

re class="brush:php;toolbar:false;">$files [ 'myfile']['a']['b'][0]['이름']; $files['myfile']['a']['b'][0]['유형']; $files['myfile']['a']['b'][0]['tmp_name']; $files['myfile']['a']['b'][0]['error']; $files['myfile']['a']['b'][0]['size'];

물론 이런 종류의 요구는 우리 일상 업무에서 드물지만 여기에 아이디어가 있습니다. 데이터를 필요한 형식으로 미리 변환하는 것은 매우 좋은 습관이며, 이는 후속 작업을 매우 간단하게 만들 수 있습니다.

위 내용은 PHP에서 여러 파일 업로드 형식을 지정하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 imooc.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제