gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-11-28 03:35:22 27 4
gpt4 key购买 nike

以下更新形式根据问卷的一些预定义答案更新密码保护区中每个用户的食物偏好数据。

例如,

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

回答:

  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 部分所示的表单?

可以解决的很长,但我期待一个合理的方法。

如果您觉得我的问题已经足够清楚了,您的回复将不胜感激。

最佳答案

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

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

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 and (isset($_POST["MM_update"])) and ($_POST["MM_update"] == "formX"))

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

关于php - 如果将所需值插入数据库,则永久禁用提交按钮 - php,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14807814/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com