php - $_POST[] 的默认值;

标签 php html sql

我对 $_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/

相关文章:

php - 如何通过一个数据库连接将 mysql 结果存储在不同的单独变量中?

javascript - jQuery - 如何选择变量的后缀并在数组中找到它的匹配项

mysql - 如何从数据库中查询/搜索某个用户的非好友姓名?

sql - 在 Access DB 中将字段拆分为多条记录

php - CakePHP 数据库结构多重关系

php - 将 HTML 从 MySQL 数据库加载到 contenteditable 标签时,浏览器行为异常

php - php session 关闭后如何重新打开它?

javascript - 如何更换搜索框?

html - CSS下拉菜单的问题

php - 计算结果集字段中包含的唯一单词总数