用户编辑帖子更新数据库

时间:2011-05-01 03:31:19

标签: php mysql

我正在尝试使用用户在论坛中编辑的帖子更新我的数据库。整个编辑表单的功能除外:当他们点击编辑时,表单提交并转到主论坛页面,但数据库和帖子不会改变。

我的保存编辑代码是:

 #data preparation for the query  
$id=intval($_POST['id']);   
$a_id=intval($_POST['a_id']); 
$question_id=intval($_POST['question_id']);
foreach ($_POST as $key => $value)  
$_POST[$key] =
mysql_real_escape_string($value); 


 $sql = "UPDATE $tbl_name SET
a_answer='$_POST[a_answer]' WHERE
a_id='$a_id' AND
question_id='$question_id'";

 if (!mysql_query($sql)) {   
die('Error: ' . mysql_error());   }  
mysql_close;   header ("location:
main_forum.php"); 

 ?>

编辑页面的代码是:

#data preparation for the query 
$id=intval($_GET['id']);  
$a_id=intval($_GET['a_id']);
$question_id=intval($_GET['question_id']);

# selects title and description fields from database
$sql = "SELECT a_answer FROM $tbl_name WHERE a_id='$a_id' AND question_id='$question_id'";
$result=mysql_query($sql);
$rows=mysql_fetch_array($result);  

?> 

和HTML

<h3>Edit</h3>
<form action="save_edit.php" method="get" name="myForm" />
<center>
  <table>
    <tr>
      <td valign="top">
        <b>Answer</b>
      </td>
      <td>
        <textarea cols="80%" rows="10" name="a_answer">
          <?php echo htmlspecialchars($rows['a_answer']); ?>
        </textarea>
      </td>
    </tr>
    <tr>
      <td colspan="3">
        <input name="a_id" type="hidden" value="&lt;? echo $rows['a_id']; ?&gt;">
          <input name="question_id" type="hidden" value="&lt;? echo $rows['question_id']; ?&gt;">
            <input type="submit" name="Submit" value="edit post">
              <?php mysql_close(); ?>
            </input>
          </input>
        </input>
      </td>
    </tr>
  </table>
</center>

1 个答案:

答案 0 :(得分:0)

您正在混淆getpost。在您的表单中,在处理页面中使用method="get"时使用$_POST。将表单更改为method="post"

  

<form action="save_edit.php" method="post" name="myForm">

PS。您不应使用/>关闭开始标记。