上传时重命名图像?

时间:2013-08-18 04:50:48

标签: php

这是我从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";
  }
?>

3 个答案:

答案 0 :(得分:1)

试试这个

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

move_uploaded_file( $_FILES['file']['tmp_name'], "upload/".$yourFileNAME."".$_FILES["file"]["type"] );

答案 1 :(得分:0)

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

答案 2 :(得分:0)

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

请注意,如果您在多个主机上同时生成标识符,可能会在相同的微秒内生成标识符

See the manual

你也可以通过mysql表生成uniqueid。

create table ids(id int auto_increment primary key);

当用户上传他们的照片时,写这样的SQL

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

希望这会对你有所帮助。