1

这是我从 W3School 中挑选的一个例子。我只是想修改它以满足我的要求。

我需要的是在上传图像时,要按顺序重命名图像,以避免重复。使用此代码,如果两个用户有两个不同的图像,但如果两个不同图像的名称偶然相同,则一个用户将收到提示“已经存在”阻止上传。

我试过更换

echo $_FILES["file"]["name"] . " already exists. ";

move_uploaded_file($_FILES["file"]["tmp_name"], "upload/" . $_FILES["file"]["tmp_name"]); echo "Stored in: " . "upload/" . $_FILES["file"]["tmp_name"];

但似乎没有给我一个解决方案。

有人可以建议我重命名按顺序上传的图像吗?谢谢。

编码:

<?php
$allowedExts = array("gif", "jpeg", "jpg", "png");
$temp = explode(".", $_FILES["file"]["name"]);
$extension = end($temp);
if ((($_FILES["file"]["type"] == "image/gif")
|| ($_FILES["file"]["type"] == "image/jpeg")
|| ($_FILES["file"]["type"] == "image/jpg")
|| ($_FILES["file"]["type"] == "image/pjpeg")
|| ($_FILES["file"]["type"] == "image/x-png")
|| ($_FILES["file"]["type"] == "image/png"))
&& ($_FILES["file"]["size"] < 2000000)
&& in_array($extension, $allowedExts))
  {
  if ($_FILES["file"]["error"] > 0)
    {
    echo "Return Code: " . $_FILES["file"]["error"] . "<br>";
    }
  else
    {
    echo "Upload: " . $_FILES["file"]["name"] . "<br>";
    echo "Type: " . $_FILES["file"]["type"] . "<br>";
    echo "Size: " . ($_FILES["file"]["size"] / 1024) . " kB<br>";
    echo "Temp file: " . $_FILES["file"]["tmp_name"] . "<br>";

    if (file_exists("upload/" . $_FILES["file"]["name"]))
      {
      echo $_FILES["file"]["name"] . " already exists. ";
      }
    else
      {
      move_uploaded_file($_FILES["file"]["tmp_name"],
      "upload/" . $_FILES["file"]["name"]);
      echo "Stored in: " . "upload/" . $_FILES["file"]["name"];
      }
    }
  }
else
  {
  echo "Invalid file";
  }
?>
4

3 回答 3

1

尝试这个

在移动上传的文件时,将文件名更改$yourFileNAME为某个唯一值,例如用户名或用户 ID,以便没有两个文件具有相同的名称。

move_uploaded_file( $_FILES['file']['tmp_name'], "upload/".$yourFileNAME."".$_FILES["file"]["type"] );
于 2013-08-18T04:57:01.243 回答
0

只需更改此行: move_uploaded_file($_FILES["file"]["tmp_name"],"upload/" . $your_file_name) 对于您的图像名称,您可以使用文件的 md5 和时间戳来创建唯一的序列

于 2013-08-18T04:55:22.237 回答
0

使用uniqid()PHP 函数可能是您最好的方法。

请注意,如果您在多个主机上同时生成标识符,则可能恰好在同一微秒生成标识符

见手册

您还可以通过 mysql 表生成 uniqueid。

create table ids(id int auto_increment primary key);

当用户上传他们的图片时,这样写sql

insert into ids () values();
select last_insert_id();

希望这会帮助你。

于 2013-08-18T05:10:40.280 回答