來簡單講一下透過 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 流程上就會更好也更清楚了。