php - 在提交表单上使用 PHP 中的 echo 将数据显示到表中

标签 php html mysql

我有一个表格,显示有回显,其中,对于每一行,我希望有一个按钮来更改“状态”字段(我只想更新一个字段)。我试图在回显中插入一个表单按钮,但我什么也没得到。

这是我的回显代码:

while($row = mysql_fetch_array( $result )) {
    echo "<tr>";
        echo '<td>' . $row['id'] . '</td>';
        echo '<td>' . $row['fullname'] . '</td>';
        echo '<td>' . $row['message'] . '</td>';
        echo '<td>' . $row['country'] . '</td>';
        echo '<td>' . $row['email'] . '</td>';
        echo '<td>' . $row['website'] . '</td>';
        echo '<td>' . $row['date'] . '</td>';
        echo "<td>" . $row['status'] . " </td>";

        echo "<form action='updatestatus.php' method='post'>";
            echo "<input type='hidden' value='".$row['id']."' name='id' />";
            echo "<input type='hidden' value='".$row['status']."' name='status' />";
            echo "<td><input type='submit' name='submit' value='Submit'></td>";
        echo "</form>";

        echo '<td><a href="edit.php?id=' . $row['id'] . '">Edit</a></td>';
        echo '<td><a href="delete.php?id=' . $row['id'] . '">Delete</a></td>';
    echo "</tr>"; 
}

updatestatus.php

// check if the form has been submitted. 
if (isset($_POST['submit'])) { 
    // confirm that the 'id' value is a valid integer before getting the form data
    if (is_numeric($_POST['id'])) {
        // get form data, making sure it is valid
        $id = $_POST['id'];
        $status = $_POST['status'];

        if ($status == 0) {
            $status == 1;
            mysql_query("UPDATE personalguestbook SET status='$status' WHERE id='$id'")
            or die(mysql_error());
        } else {
            $status == 0;
            mysql_query("UPDATE personalguestbook SET status='$status' WHERE id='$id'")
            or die(mysql_error()); 
        }
        header("Location: view.php"); 
    }
}

因此,如果我的状态字段为 = 0,我想将其更改为 = 1 并更新到我的数据库中,反之亦然。

感谢您的关注

最佳答案

您的表单不会向 updatestatus.php 发送任何内容,您可以将数据添加到隐藏表单中的 POST,如下所示:

echo "<form action='updatestatus.php' method='post'>";
echo "<input type='hidden' value='".$row['id']."' name='id' />";
echo "<input type='hidden' value='".$row['status']."' name='status' />";
echo "<td><input type='submit' name='submit' value='Submit'></td>";
echo "</form>";

这是对上面代码的简单修复,仍然存在一些其他人在评论中提到的安全缺陷和效率方法。

关于php - 在提交表单上使用 PHP 中的 echo 将数据显示到表中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41999749/

相关文章:

javascript - 使用文本区域在表单中添加行 [php]

javascript - 有人知道这里使用了什么 Javascript 库吗?

html - 如何使我的索引页面上的帖子出于样式目的分离元素?

mysql - 如何在我的表格中插入当前日期?

mysql - 即使表和引擎的数据类型相同也无法创建外键?

php - 如何回显/打印语句

php - Symfony2 : Twig: Default template file in custom location

php - 逻辑运算符,||或?

php - 从数据库填充下拉列表

html - 如何在主菜单中显示顶级菜单?