1

データベースを簡単に更新できるように、コンテンツ管理システムを作成しています。ユーザーがデータベースのエントリを編集できる更新ページを作成しました。ユーザーは新しい画像をアップロードして、問題なくフィールドを編集できます。私が抱えている問題は、編集したいだけで、1 つのフィールドのテキストだけを言うが、画像を変更したくない場合、フォームが送信されると、画像フィールドが空白のエントリで上書きされることです。私ができるようにしたいのは、他のファイルが選択されていない場合に元の画像を残すことです。ファイルが選択されているかどうかを確認する必要があることはわかっていますが、うまくいく方法が見つからないようです。おそらく単純なものだと思いますが、アップロード用のスクリプトは次のとおりです。

     $editFormAction = $_SERVER['PHP_SELF'];
if (isset($_SERVER['QUERY_STRING'])) {
/* upload image script */

$thumb=basename($_FILES['thumb']['name']);
if(move_uploaded_file($_FILES['thumb']['tmp_name'],"../shopImages/".$thumb))

$image1=basename($_FILES['image_1']['name']);
if(move_uploaded_file($_FILES['image_1']['tmp_name'],"../shopImages/".$image1))

$image2=basename($_FILES['image_2']['name']);
if(move_uploaded_file($_FILES['image_2']['tmp_name'],"../shopImages/".$image2))

/*end of script*/
$editFormAction .= "?" . htmlentities($_SERVER['QUERY_STRING']);
}


if ((isset($_POST["MM_update"])) && ($_POST["MM_update"] == "form1")) {
 $updateSQL = sprintf("UPDATE tbl_products SET thumb=%s, image_1=%s, image_2=%s, title=%s, `desc`=%s, category_id=%s, status=%s, shipping_band=%s, price=%s WHERE product_id=%s",
                   GetSQLValueString($thumb, "text"),
                   GetSQLValueString($image1, "text"),
                   GetSQLValueString($image2, "text"),
                   GetSQLValueString($_POST['title'], "text"),
                   GetSQLValueString($_POST['desc'], "text"),
                   GetSQLValueString($_POST['category_id'], "int"),
                   GetSQLValueString($_POST['status'], "int"),
                   GetSQLValueString($_POST['shipping_band'], "text"),
                   GetSQLValueString($_POST['price'], "double"),
                   GetSQLValueString($_POST['product_id'], "int"));

フォームのコードは次のとおりです。

<form method="post" name="form1" action="<?php echo $editFormAction; ?>" enctype="multipart/form-data">
  <table align="center">
    <tr valign="baseline">
       <td nowrap align="right">Product ID:</td>
      <td>

    <?php echo $row_RS_updateProducts['product_id']?>

  </td>
<tr>
<tr valign="baseline">
  <td nowrap align="right">Thumb:</td>
  <td><?php echo $row_RS_updateProducts['thumb']?><input type="file" name="thumb" value="<?php echo $row_RS_updateProducts['thumb']?>" size="32"></td>

</tr>
<tr valign="baseline">
  <td nowrap align="right">Image 1:</td>
  <td><?php echo $row_RS_updateProducts['image_1']?><input type="file" name="image_1" value="<?php echo $row_RS_updateProducts['image_1']?>" size="32"></td>
</tr>
<tr valign="baseline">
  <td nowrap align="right">Image 2:</td>
  <td><?php echo $row_RS_updateProducts['image_2']?><input type="file" name="image_2" value="<?php echo $row_RS_updateProducts['image_2']?>" size="32"></td>
</tr>
<tr valign="baseline">
  <td nowrap align="right">Title:</td>
  <td><input type="text" name="title" value="<?php echo htmlentities($row_RS_updateProducts['title'], ENT_COMPAT, 'UTF-8'); ?>" size="32"></td>
</tr>
<tr valign="baseline">
  <td nowrap align="right">Description:</td>
  <td><input type="text" name="desc" value="<?php echo htmlentities($row_RS_updateProducts['desc'], ENT_COMPAT, 'UTF-8'); ?>" size="32"></td>
</tr>
<tr valign="baseline">
  <td nowrap align="right">Category:</td>
  <td><select name="category_id">
    <?php 
do {  
?>
    <option value="<?php echo $row_RS_Category['category_id']?>" <?php if (!(strcmp($row_RS_Category['category_id'], htmlentities($row_RS_updateProducts['category_id'], ENT_COMPAT, 'UTF-8')))) {echo "SELECTED";} ?>><?php echo $row_RS_Category['category_name']?></option>
    <?php
} while ($row_RS_Category = mysql_fetch_assoc($RS_Category));
?>
  </select></td>
<tr>
<tr valign="baseline">
  <td nowrap align="right">Status:</td>
  <td><select name="status">
    <option value="1" <?php if (!(strcmp(1, htmlentities($row_RS_updateProducts['status'], ENT_COMPAT, 'UTF-8')))) {echo "SELECTED";} ?>>Available</option>
    <option value="2" <?php if (!(strcmp(2, htmlentities($row_RS_updateProducts['status'], ENT_COMPAT, 'UTF-8')))) {echo "SELECTED";} ?>>Pending</option>
    <option value="3" <?php if (!(strcmp(3, htmlentities($row_RS_updateProducts['status'], ENT_COMPAT, 'UTF-8')))) {echo "SELECTED";} ?>>Unavailable</option>
  </select></td>
</tr>
<tr valign="baseline">
  <td nowrap align="right">Shipping Band:</td>
  <td><select name="shipping_band">
    <option value="a" <?php if (!(strcmp("a", htmlentities($row_RS_updateProducts['shipping_band'], ENT_COMPAT, 'UTF-8')))) {echo "SELECTED";} ?>>A</option>
    <option value="b" <?php if (!(strcmp("b", htmlentities($row_RS_updateProducts['shipping_band'], ENT_COMPAT, 'UTF-8')))) {echo "SELECTED";} ?>>B</option>
    <option value="c" <?php if (!(strcmp("c", htmlentities($row_RS_updateProducts['shipping_band'], ENT_COMPAT, 'UTF-8')))) {echo "SELECTED";} ?>>C</option>
    <option value="d" <?php if (!(strcmp("d", htmlentities($row_RS_updateProducts['shipping_band'], ENT_COMPAT, 'UTF-8')))) {echo "SELECTED";} ?>>D</option>
  </select></td>
</tr>
<tr valign="baseline">
  <td nowrap align="right">Price:</td>
  <td><input type="text" name="price" value="<?php echo htmlentities($row_RS_updateProducts['price'], ENT_COMPAT, 'UTF-8'); ?>" size="32"></td>
</tr>
<tr valign="baseline">
  <td nowrap align="right">&nbsp;</td>
  <td><input type="submit" value="Update record"></td>
</tr>
  </table>
  <input type="hidden" name="MM_update" value="form1">
  <input type="hidden" name="product_id" value="<?php echo $row_RS_updateProducts['product_id']; ?>">
</form>

私はphpが初めてなので、何日もこれにこだわっているので、助けていただければ幸いです。

4

2 に答える 2

0

ファイルの移動ロジックを実行する前に $_FILES コンポーネントを確認してください

このような:

if(!empty($_FILES['thumb']['name'])){
   $thumb = basename( $_FILES['thumb']['name'] );
   move_uploaded_file($_FILES['thumb']['tmp_name'],"../shopImages/".$thumb);
}
if(!empty($_FILES['image_1']['name'])){
   $image1 = basename( $_FILES['image_1']['name'] );
   move_uploaded_file($_FILES['image_1']['tmp_name'],"../shopImages/".$image1);
}
if(!empty($_FILES['image_2']['name'])){
   $image2 = basename( $_FILES['image_2']['name'] );
   move_uploaded_file($_FILES['image_2']['tmp_name'],"../shopImages/".$image2);
}

クエリを次のように変更します。

$updateSQL = sprintf("UPDATE tbl_products SET title=%s, `desc`=%s, category_id=%s, status=%s, shipping_band=%s, price=%s ",
               GetSQLValueString($_POST['title'], "text"),
               GetSQLValueString($_POST['desc'], "text"),
               GetSQLValueString($_POST['category_id'], "int"),
               GetSQLValueString($_POST['status'], "int"),
               GetSQLValueString($_POST['shipping_band'], "text"),
               GetSQLValueString($_POST['price'], "double"));

if(isset($thumb)){
  $updateSql .= sprintf(" thumb=%s", GetSQLValueString($thumb, "text"));
}

if(isset($image1)){
  $updateSql .= sprintf(" image_1=%s", GetSQLValueString($image1, "text"));
}

if(isset($image2)){
  $updateSql .= sprintf(" image_2=%s", GetSQLValueString($image2, "text"));
}

$updateSql .= sprintf(" WHERE product_id=%s", GetSQLValueString($_POST['product_id'], "int"));
于 2013-07-23T09:55:16.373 に答える
0

have you mentioned in your form

<form name="form_name" action="actionpage.php" enctype="multipart/form-data" method="post">

if you have not written enctype="multipart/form-data" your file will not be uploaded.

于 2013-07-23T09:51:29.063 に答える