繁体   English   中英

如何检查是否用foreach循环设置了所有$ _POST变量

[英]How to check if all $_POST variables are set with foreach loop

我想检查是否设置了给定的$ _post变量,然后执行查询(这是另一个主题)。但是我有5个小时的麻烦,我无法真正通过它。

<?php
function post_category_isset()
{
    global $connect;

    $input = sanitize('category');
    $query = mysqli_query($connect, "SELECT term_id FROM term_taxonomy WHERE taxonomy = '$input'");

    while ($row = mysqli_fetch_assoc($query)) {

        $category_id [] = $row['term_id'];
        $result = '\'' . implode('\',\'', $category_id) . '\'';

        foreach ($row as $result) {

            $query1 = mysqli_query($connect, "SELECT name FROM terms WHERE term_id = $result");
            $fetch = mysqli_fetch_assoc($query1);
            $value = $fetch['name'];
            if (isset($_POST[$value])) {
                echo "if(isset($_POST[$value]) OR";

                return true;
            }
        }
    }
}


?>

我已经尝试了一切,是的,代码看起来确实很愚蠢,但是我已经耗尽了...

所以我做了功能检查类别变量设置,这是另一种功能,因为我想要的一切是自动。我会贴上我的其他FUNC在引擎收录,因为它是线程的出在这里

所以总之我想做一个函数来检查以前函数中的所有$ _POST变量是否都已设置,如果是,则触发查询。

谢谢!

您不必在这里使用两个单独的查询,您只需一个查询即可完成所有操作。

SELECT name 
FROM terms 
WHERE term_id IN (
    SELECT term_id 
    FROM term_taxonomy 
    WHERE taxonomy = '$input'
)

因此,您的post_category_isset()函数将如下所示:

function post_category_isset(){
    global $connect;

    $input = sanitize('category');
    $query = mysqli_query($connect, "SELECT name FROM terms WHERE term_id IN (SELECT term_id FROM term_taxonomy WHERE taxonomy = '$input')");
    while ($row = mysqli_fetch_assoc($query)) {
        $value = $row['name'];
        if (isset($_POST[$value])) {
            // your code
        }
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM