如何使用 Foreach 为每个用户上传不同名称的相同文件

How to Upload the Same File in Different Names for Each Users Using Foreach

通过 foreach 工作的其他查询 loop.but array.this 的第一个索引的文件上传不是多个文件 upload.i 想为每个用户上传不同名称的相同文件。

    foreach($_POST['groupmem'] as $user){
    //Some Queries

    $filename2 = str_replace(" ", "_","{$user}.{$_FILES['proposal']['name']}");
    $destination2 = '../img/proposal/' . $filename2;
    $extension2 = pathinfo($filename2, PATHINFO_EXTENSION);
    $file2 = $_FILES['proposal']['tmp_name'];
    $size2 = $_FILES['proposal']['size'];
    if (!in_array($extension2, ['zip', 'pdf', 'docx'])) {
        echo "You file extension must be .zip, .pdf or .docx";
    } elseif ($_FILES['proposal']['size'] > 200000000) { // file shouldn't be larger than 200Megabyte
        echo "File too large!";
    } else {
        if (move_uploaded_file($file2, $destination2)) {
            $sql = "UPDATE project SET proposal_name='$filename2' WHERE u_id='{$user}' ";
            if (mysqli_query($conn, $sql)) {
                echo "File uploaded successfully";
            }
        } else {
            echo "Failed to upload file.";
        }
    }
    }

你不能在循环内做move_uploaded_file

$user1 = $_POST['groupmem'][0];
$filename1 = str_replace(" ", "_","{$user1}.{$_FILES['proposal']['name']}");
$destination1 = '../img/proposal/' . $filename1;
$extension1 = pathinfo($filename1, PATHINFO_EXTENSION);
$file1 = $_FILES['proposal']['tmp_name'];
$size1 = $_FILES['proposal']['size'];
if (!in_array($extension1, ['zip', 'pdf', 'docx'])) {
    echo "You file extension must be .zip, .pdf or .docx";
} elseif ($_FILES['proposal']['size'] > 200000000) { // file shouldn't be larger than 200Megabyte
    echo "File too large!";
} else {
    if (move_uploaded_file($file1, $destination1)) {

    foreach($_POST['groupmem'] as $user){
        $filename2 = str_replace(" ", "_","{$user}.{$_FILES['proposal']['name']}");
        $destination2 = '../img/proposal/' . $filename2;
        if ($user <> $user1) {
            if (!copy($destination1, $destination2))  echo "failed to copy $file...\n";
        }

        $sql = "UPDATE project SET proposal_name='$filename2' WHERE u_id='{$user}' ";
        if (mysqli_query($conn, $sql)) {
        echo "File uploaded successfully";
        }
    }

    } else {
        echo "Failed to upload file.";
    }

}