來簡單講一下透過 PHP 修改圖片的做法,首先我們有一個這樣的資料表,內容為:
![]()
透過 query 把內容撈出來:
$id=$_GET["id"];
$stmt=$db_host->prepare("SELECT * FROM product WHERE id=?");
try{
$stmt->execute([$id]);
$row=$stmt->fetch();
}catch(PDOExecption $e){
echo "讀取資料失敗";
}
接下來把讀取出來的資料顯示在頁面上:
<form action="updateProduct.php" method="post" enctype="multipart/form-data">
<!-- 存 id 要 post 時抓的 -->
<input type="hidden" name="id" value="<?=$id?>">
<div class="form-group">
<input type="text" class="form-control" name="name" value="<?=$row["name"]?>">
</div>
<div class="form-group">
<!-- 把原本的圖片資訊存在 hidden 裡,post 之後用來判斷是否要替換圖片 -->
<input type="hidden" name="old_img" value="<?=$row["img"]?>">
<img src="img/<?=$row["img"]?>" alt="">
<input type="file" name="file">
</div>
<button class="btn btn-info" type="submit">儲存</button>
</form>
注意要上傳檔案一定要設定 enctype,然後要把像 id 跟原始圖片檔名的資訊存在 hidden 的 input 裡,等等 post 到後端會用到。
接著寫在後端處理資料的部分:
$id=$_POST["id"];
$name=$_POST["name"];
$old_img=$_POST["old_img"];
if ($_FILES['file']['error'] == 0){
#如果有選擇圖片就使用新上傳的圖片
$filename=$_FILES['file']['name'];
#上傳圖片
if(move_uploaded_file($_FILES['file']['tmp_name'], './img/'.$filename)){
echo "success";
}else{
echo "fail";
}
} else {
echo $_FILES['file']['error'];
#如果沒有選擇圖片就使用原本資料庫的圖片
$filename=$old_img;
}
$sql="UPDATE product SET name=?, img=? WHERE id=?";
$stmt=$db_host->prepare($sql);
$stmt->execute([$name, $filename, $id]);
header("location: product.php?id=".$id)
因為圖片不一定有更新,所以在程式裡判斷如果沒有夾帶檔案,則把原本的圖片檔名再存回去,有夾帶檔案的話就一樣走上傳的流程取得圖檔後更新到資料庫。
這樣就是簡單的做法,要做更好的話在顯示頁那邊一般會做一個按鈕去刪除目前的圖片,刪除後才會出現上傳圖片的欄位,這樣在 UI 流程上就會更好也更清楚了。