如何使用PHP、提交和单选按钮复制/重命名/覆盖图像


How can I copy/rename/overwrite image using PHP, submit and radio buttons?

我刚开始使用PHP,我正在尝试为客户端提供一种方法,使其能够使用单选按钮和表单提交来更改图像。我的意图是将两个图像文件中的一个(Open/Closed.jpg)复制并重命名到另一个位置(images/status/status.jpg),这样就不需要编码来进行更改。

"新"图像将在其他地方使用。我尝试过各种copy()和rename()调用,但都没有成功。下面是我正在使用的代码。我觉得我的问题在于提交电话,但我尝试的所有方法都没有奏效。因此,我回到了我的原始代码(下面),在经验丰富的用户/程序员的帮助下,尝试一个全新的开始。

<head>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
<meta name="description" content="">
<meta name="keywords" content="">
<title></title>
<link href="style.css" type="text/css" rel="stylesheet" />
</head>
<body>
<?php 
// define variables and set to empty values
$WinterStatusErr = "";
$WinterStatus = "";
if ($_SERVER["REQUEST_METHOD"] == "POST")
{
   if (empty($_POST["WinterStatus"]))
     {$WinterStatusErr = "Status is required";}
   else
     {$WinterStatus = test_input($_POST["WinterStatus"]);}
}
function test_input($data)
{
     $data = trim($data);
     $data = stripslashes($data);
     $data = htmlspecialchars($data);
     return $data;
}
?>
<p><span class="error"><font color="red"><b>* required selection</b></font></span></p>
<form method="post" action="<?php echo htmlspecialchars($_SERVER["PHP_SELF"]);?>"> 
   <input type="radio" name="WinterStatus" <?php if (isset($WinterStatus) &&          $WinterStatus=="open") echo "checked";?>  value="Open">Open
   <input type="radio" name="WinterStatus" <?php if (isset($WinterStatus) && $WinterStatus=="closed") echo "checked";?>  value="Closed">Closed
   <span class="error"><font color="red"><b>* <?php echo $WinterStatusErr;?></b></font></span>
   <br><br>
   <input type="submit" name="submit" value="Submit" <?php
if ($Winterstatus == "Open")
    { copy ("images/Open.jpg", "images/status/Status.jpg"); }
   elseif ($Winterstatus == "Closed")
    { copy ("images/Closed.jpg", "images/status/Status.jpg");}
?>> 
</form>
<?php echo $WinterStatus ?>
</body>

首先从提交输入中删除if语句,然后将if语句中的$Winterstatus更改为$Winterstatus。

在php中,您可以使用exec()来执行命令。在linux上,"cp"命令应该按照您的要求执行。不过,权限/安全问题将是一个问题,所以我建议将变量更改为新图像,而不是实际移动它……更简单、更安全——如果我知道你在哪里引用图像,我可以帮助你弄清楚。