如果需要将值插入数据库 - php,则永久禁用提交按钮

时间:2013-02-11 07:41:43

标签: php html mysql forms

以下更新表格根据调查问卷的某些预定义答案更新密码保护区内每个用户的食物偏好数据。

例如,

问题:你最喜欢的食物是什么?

答案:

  1. 干酪
  2. 沙拉
  3. 当用户提交时,应根据变量$trigger的预定义值永久禁用以下表单的提交按钮。

    $trigger = '1';
    if ((isset($_POST["MM_update"])) && ($_POST["MM_update"] == "formX")) { 
    $updateSQL = sprintf("UPDATE foodtable SET food_preference=%s, trigger=%s, WHERE food_id=%s",    
                           GetSQLValueString($_POST['food_preference'], "text"),
                           GetSQLValueString(trim($trigger), "int"),
                           GetSQLValueString($_POST['food_id'], "int"));
    
      mysql_select_db($database_XYZ, $XYZ);
      $Result1 = mysql_query($updateSQL, $XYZ) or die(mysql_error());
    
      $updateGoTo = "preference.php";
      if (isset($_SERVER['QUERY_STRING'])) {
        $updateGoTo .= (strpos($updateGoTo, '?')) ? "&" : "?";
        $updateGoTo .= $_SERVER['QUERY_STRING'];
          }
      header(sprintf("Location: %s", $updateGoTo));
        exit ();
    }
    

    <form action="<?php echo $editFormAction; ?>" method="post" name="formX" id="formX">
    <table align="center">
      <tr valign="baseline">
        <td align="right" nowrap="nowrap">Update Food Name:</td>
        <td><input type="text" name="food_name" value="" size="32" /></td>
      </tr>
       <tr valign="baseline">
        <td nowrap="nowrap" align="right">
         <input type="hidden" name="MM_update" value="formX" />
         <input type="hidden" name="trigger" value="<?php echo "$trigger"; ?>" />
         </td>
                        <td>
                        <input type="submit" value="Update Food Name" />
                        </td>
                      </tr>
                    </table>
                  </form>
    

    如何使用纯php条件语句执行它?我是否应该更改html表单代码?任何参考或建议都应该得到很好的赞赏。


    修改

    以下更新表单更新了受密码保护的用户区域中个人用户的食物偏好。

     $trigger = '1';  
    //note: default value of $trigger= '0'; when user submits data using insert form primarily. when they update data using this update form the value changes to `1`
    
    if ((isset($_POST["MM_update"])) && ($_POST["MM_update"] == "formX")) { 
    $updateSQL = sprintf("UPDATE foodtable SET food_name=%s, trigger=%s WHERE food_id=%s",    
                           GetSQLValueString($_POST['food_name'], "text"),
                           GetSQLValueString(trim($trigger), "int"),
                           GetSQLValueString($_POST['food_id'], "int"));
    
      mysql_select_db($database_XYZ, $XYZ);
      $Result1 = mysql_query($updateSQL, $XYZ) or die(mysql_error());
    
      $updateGoTo = "preference.php";
      if (isset($_SERVER['QUERY_STRING'])) {
        $updateGoTo .= (strpos($updateGoTo, '?')) ? "&" : "?";
        $updateGoTo .= $_SERVER['QUERY_STRING'];
          }
      header(sprintf("Location: %s", $updateGoTo));
        exit ();
    }  
    

        <form action="<?php echo $editFormAction; ?>" method="post" name="formX" id="formX">
    <table align="center">
      <tr valign="baseline">
        <td align="right" nowrap="nowrap">Update Food Name:</td>
        <td><input type="text" name="food_name" value="" size="32" /></td>
      </tr>
       <tr valign="baseline">
        <td nowrap="nowrap" align="right">
         <input type="hidden" name="MM_update" value="formX" />
        <input type="hidden" name="food_id" value="<?php echo $query['food_id']; ?>" />
         <input type="hidden" name="trigger" value="<?php echo "$trigger"; ?>" />
         </td>
         <td>
          < ?php 
            $disabled = "disabled";
            if (isset (which conditional statement shall disable the form permanently based on $trigger = '1'; ?)) {
            echo "<input type='submit' value='Update Food Name' " . $disabled . "/>";
            }else{
            echo "<input type='submit' value='Update Food Name'/>";
            } 
           ?>
                        </td>
                      </tr>
                    </table>
                  </form>
    

    顺便说一句,我使用以下mysql语法来获取用于禁用提交按钮的列值:

    $query = "SELECT food_id, food_name, trigger FROM foodtable WHERE food_id > 0 AND trigger = '1'";
    

    我应该使用哪些条件php语句来禁用表格,如此编辑帖子的html部分所示?

    它可以用很长的方式解决,但我期待一种合理的方法。

    如果您觉得我的问题足够清楚,那么您的回复将会得到很好的赞赏。

1 个答案:

答案 0 :(得分:0)

我会按照以下方式进行。一旦用户提交表单,就会将标志写入他的会话中(但是我建议将这些数据存储在数据库中,因为如果他关闭然后重新打开浏览器会话将被重置;但是这段代码应该可以帮助你开始)。 / p>

首先,在脚本开始时初始化会话:

session_start();

然后,在更新之前,检查他是否尚未提交数据:

if ((!isset($_SESSION['has_submitted']) or !$_SESSION['has_submitted'])
    and (isset($_POST["MM_update"])) and ($_POST["MM_update"] == "formX")) { 

当然,您需要在更新后设置标志:

$Result1 = mysql_query($updateSQL, $XYZ) or die(mysql_error());
$_SESSION['has_submitted'] = TRUE;

最后,当您回显提交按钮时,您只需检查此标记并采取相应措施:

<input type="submit" value="Update Food Name" <?php echo ((isset($_SESSION['has_submitted']) and $_SESSION['has_submitted']) ? 'disabled' : ''); ?> />

修改

当用户进入页面时,您需要获取当前的trigger值:

$trigger = mysql_query("select trigger from foodtable where food_id=...");

然后,您只需在输出或提交表单时检查$trigger变量(假设用户以某种方式启用了表单):

if(!$ trigger和(isset($ _ POST [“MM_update”]))和($ _POST [“MM_update”] ==“formX”))

<input type="submit" value="Update Food Name" <?php echo ($trigger ? 'disabled' : ''); ?> />