Php sql,表单在页面加载时重新提交

标签 php mysql sql forms

忽略 mysql 和 nor sql 转义字符串的明显安全缺陷,有谁知道为什么我的 sql 表在页面重新加载时被空的 msgs 填满。 每次页面重新加载时都会提交表单。我很困惑为什么会这样,我该如何阻止它?

  <?php
    ob_start();
    session_start();
    $con = mysql_connect("localhost","username","pass");
    if (!$con)
      {
      die('Could not connect: ' . mysql_error());
      }

    $dates = date('Y-m-d H:i:s');
    $uid = $_SESSION['user_id'];
    $msg_id = (int) $_GET['msg_id'];
    mysql_select_db("db_table", $con);

    $result = mysql_query("SELECT users.first_name, users.last_name ,  intro.intro, intro.outro FROM intro INNER JOIN users ON intro.user_id = users.user_id WHERE intro.message_id = {$msg_id}");
    while($row = mysql_fetch_array($result))
    {
       echo  "<div id=\"start\"><div class=\"namedate\"><h1>". $row['first_name'] ." ".  $row['last_name'] .  "</h1><h2>test</h2></div><div id=\"holdmsg\"><div class=\"cent\"><strong>" . $row['intro'] . "</strong><br><i>" . $row['outro'] ."</i></div></div></div> "  ;
    }

与表单相关的部分是页面顶部的这部分以及 $_GET。

<form action="" method="post">      
<?php 

$sql="INSERT INTO messages (user_id, intro_id , msg, date ) VALUES (('$uid'), {$msg_id} ,'$_POST[msg]', ('$dates'))";

if (!mysql_query($sql,$con))
  {
  die('Error: ' . mysql_error());
  }

mysql_close($con);

?>

    <textarea rows="2"style="float:left" name="msg" type="text"placeholder="Elaborate on your idea..."></textarea>
    <input id="togz2" style="float:right; "type="submit" value="SUBMIT" name="submit" class="butts">
    </div></div>
</form>

最佳答案

为什么不这样做呢?

if (mysql_query($sql,$con))
  {
   header('location:yourpage.php');
}else{
  die('Error: ' . mysql_error());
}

此外,我在您的插入查询上方没有看到任何此类声明 喜欢

if(isset($_REQUEST['submit'])){ //to check if posted

  $sql="INSERT ......
}

除此之外,您还应该在将数据插入数据库之前验证数据。

关于Php sql,表单在页面加载时重新提交,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14455417/

相关文章:

php - 既然可以直接使用 PHP,为什么还要 Sass 或 LESS?

php - 理解 php 中的类型提示和命名空间

php - 我怎样才能更好地显示我的数据。我有问题

php - foreach 中的数据用于更新查询

sql - MS Access 在所有列中循环联合查询?

php - 在 Wordpress 高级自定义字段 PRO 中将行添加到嵌套重复器

python - 设置 %s 的 Mysqldb 更新错误

MYSQL 更新无法使用多个 `AND` 语句

mysql - SQL 语句帮助 - 仅选择过去 3 个月没有订单的客户

mysql 选择不同的行到逗号分隔的列表列中