我正在尝试编写一个 PHP 项目。在这个站点中,人们可以通过登录来分享照片,照片显示在程序主页的 index.php 中。现在我有三个数据库用户的图像和消息。我可以提供用户通过保存有关照片的信息来分享他们的照片,然后从图像表中从数据库中获取它们。现在我想提供一个用户对主页中的照片进行评论。下面有 textarea 和 post 按钮图像。但是当我对图像进行评论时,它不仅会注册相关的图片 ID,还会注册其他图片 ID。为什么会发生这种情况?
这是php代码的一些部分,我也在必要的部分打开和关闭了数据库连接。
while($x < mysql_num_rows($result))
{
$picid=mysql_result($result, $x, 'id');
$name=mysql_result($result, $x, 'imageName');
$date=mysql_result($result, $x, 'imageDate');
echo "<div><img src = 'upload/$name' height='300 width='300' /></div>";
echo "Name: $name Date: $date";
echo "<br/>";
?>
<p>Post a Comment</p>
<form action="<?= $_SERVER['PHP_SELF']?>" method="POST">
<textarea name="message" cols="70" rows="6" placeholder="Enter a comment">
</textarea><br/><br/><br/><br/><br/><br/>
<input type="submit" name="submit" value="Post" style="float:left"><br/><br/>
<br/>
</form>
<!--<textarea name="message" cols="70" rows="6" ></textarea><br/><br/><br/><br/>
<br/><br/>-->
<?php
extract($_REQUEST);
if (isset($submit)) {
$y=0;
$email=$_SESSION['email'];
$asdf = mysql_query("SELECT * from users WHERE email='$email'");
//var_dump(mysql_error());
while( $y<mysql_num_rows($asdf) )
{
$iduser=mysql_result($asdf,$y,'id');
$y++;
}
echo "$iduser";
$sql ="INSERT INTO messages (id_user, message,picid) VALUES
('$iduser','$message','$picid');";
$rslt = mysql_query($sql);
if ($rslt== false) {
echo '<p>Error: cannot execute query</p>';
}
} ?>
<?php
$x++;
}