gpt4 book ai didi

php - $_POST[] 的默认值;

转载 作者:可可西里 更新时间:2023-10-31 22:41:34 24 4
gpt4 key购买 nike

我对 $_POST[] 的默认值有疑问;所以我有一个带有文本框的 html 表单,信息被发送到一个 php 脚本。 php 脚本有一个 sql 查询被发送到我的数据库。但是,如果我的 html 形式的文本框为空,则查询没有值。所以我想将我的帖子设置为默认值 0,以便它至少返回一个值。

所以这是一个 html 表单的例子(这不是我的实际脚本。只是一个例子。

<form action="testscript.php" method="POST">
<input type="id" name="ID"/>
<input type="text" name="test"/>
<input type="submit" value="Send"/>
</form>

好的,所以这个脚本将同时发送 id 和测试文本框将始终有一个数字值。并将信息发送到 testscript.php

这里是 testscript.php 例子

    $conn = mysqli_connect('host', 'dbuser', 'dbpass', 'dbname');
$id = $_POST['id'];
$test = $_POST['test'];
$sql = "INSERT INTO test_table (id, test) VALUES ($id, $test)";

if (mysqli_query($conn, $query)) {
echo "Success";
} else {
echo "Failed" . mysqli_error($conn);
}

好吧,现在如果我将我的 html 表单提交到 php 脚本而不向文本框插入任何文本,查询将如下所示

INSERT INTO test_table (id, test) VALUES ( , )

但是查询应该是这样的

INSERT INTO test_table (id, test) VALUES (0, 0)

所以。我知道我可以在 html 标记中使用 value 属性,但是该值将在文本框中可见,我不希望这样。

我知道我可以做一个 if 语句来创建这样的默认值

if (isset($_POST['test'])) {
$test = $_POST['test'];
} else {
$test = 0;
}

但现在的问题是,如果每个文本框的声明和我的 html 表单有超过 100 个文本框,我将不得不这样做。所以我不想为每个文本框做一个 if 语句,因为那样我的脚本会很大,需要几个小时。

那么有什么方法可以为所有文本框设置一个默认值,而无需使用 php 中的 if 语句或 html 表单中的 value 属性?

最佳答案

我知道这看起来很痛苦,但您必须检查所有输入是否有效。您可以使用像这样的三元运算符来简化代码量。

$id = isset($_POST['id']) ? $_POST['id'] : 0;
$test = isset($_POST['test']) ? $_POST['test'] : 0;

....

不,即使有数百个,也不会花费数小时。

为了稍微减少编码的痛苦,您可以使用 PHP 的 variable variables 的循环功能。

最痛苦的部分是创建一个包含所有字段名称的数组

$fields = array('id', 'test', 'extra', 'more', ..., 'one_hundred');

然后遍历该数组创建变量名,同时转义字符串 - 如果它们存在 - 否则设置值 0(零)。您可能希望/需要将其设置为“”(空字符串)

foreach($fields as $field_name)
{
${$field_name} = isset($_POST[$field_name]) ? mysqli_real_escape_string($conn, $_POST[$field_name]) : 0;
}

您现在可以使用变量 $id、$test、$extra、$more、....、$one_hundred。

关于php - $_POST[] 的默认值;,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34029663/

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