0

当我在 OOP PHP 中使用 MVC 框架并提交表单时,我必须刷新页面才能继续下一个“elseif”。

即使函数“$login->isConfigFileCreated()”现在返回 true(在执行类构造器之后),它仍显示与以前相同的视图,并且需要刷新才能“继续”。

我确定,问题不在于“createConfigFile() 函数”。这对我来说是一个常见的问题。

<?php

require_once("db.php");
require_once("classes/Login.php");

$login = new Login();

**if ($login->isConfigFileCreated() == false)
{
    include("views/config_file.php");
}
elseif ($login->isAdminCreated() == false)
{
    include("views/register.php");
}**
else
{
    include("views/not_logged_in.php");
}

config_file.php 视图文件如下所示:

<form method="post" action="" name="create_config_file">
        <input type="text" name="input_db_host" required />
        <input type="text" name="input_db_name" required />
        <input type="text" name="input_db_user" required />
        <input type="text" name="input_db_pass" required />
        <input type="submit" name="create_config_file" value="Create" />
</form>

例如,具有函数的类看起来像这样:

public function __construct()
    {
        if (isset($_POST["create_config_file"]))
        {
            $this->createConfigFile();
        }
        if (isset($_POST["register"]))
        {
            $this->register();
        }
    }
public function isAdminCreated()
    {
        $this->db_connection = new mysqli(DB_HOST, DB_USER, DB_PASS, DB_NAME);
        if (!$this->db_connection->connect_errno)
        {
            $checksetup = $this->db_connection->query("SELECT user_email FROM users WHERE user_id = '1';");
            if ($checksetup->num_rows == 1)
            {
                return true;
            }
            else
            {
                return false;
            }
        }
    }


public function isConfigFileCreated()
    {
        if(defined('DB_HOST') && defined('DB_NAME') && defined('DB_USER') && defined('DB_PASS'))
        {
            return true;
        }
        else
        {
            return false;
        }
    }


    public function createConfigFile($action)
    {
        if ($action == "complete")
        {
            $file_content = file_get_contents("db.php");
            $file_content .= 'define("CONFIG_DONE", "true");';
            file_put_contents("db.php", $file_content);
        }
        else
        {
            $this->db_connection = new mysqli($_POST['input_db_host'], $_POST['input_db_user'], $_POST['input_db_pass'], $_POST['input_db_name']);
            if (!$this->db_connection->connect_errno)
            {
                $file_content =    '<?php'."\n";
                $file_content .=   'define("DB_HOST", "'.$_POST['input_db_host'].'");'."\n";
                $file_content .=   'define("DB_NAME", "'.$_POST['input_db_name'].'");'."\n";
                $file_content .=   'define("DB_USER", "'.$_POST['input_db_user'].'");'."\n";
                $file_content .=   'define("DB_PASS", "'.$_POST['input_db_pass'].'");'."\n";

                file_put_contents("db.php", $file_content);
                fclose("db.php");
                $login->messages[] = "That's it! You're now ready to kick ass at some image management!";
            }
            else
            {
                $this->errors[] = "Wrong database credentials!"; 
            }
        }

    }
4

2 回答 2

1

elseif将使所有代码相关。如果您不希望它相关并希望它继续并检查下一个 if 语句,则只需删除 else:

if ($login->isConfigFileCreated() == false)
{
    include("views/config_file.php");
}

if ($login->isAdminCreated() == false)
{
    include("views/register.php");
}

if( !$login->isConfigFileCreated() && $login->isAdminCreated())
{
    include("views/not_logged_in.php");
}

这将包括 config_file.php,然后检查是否创建了管理员

在您输入后,这里是一个更新的答案:

所以问题是您正在写入的文件db.php已经包含在脚本中。

所以流程是require db.php-> 然后写入该文件。这意味着您写入此文件的更改将不可用,因为脚本已经加载。

这里的解决方案是不使用常量变量,因为它们无法更改。如果您使用常规变量,那么您可以include db.php再次覆盖之前定义的变量。

另一种选择是让您的创建配置文件返回需要定义的值,以便您可以覆盖之前已经包含的内容。

于 2013-07-02T20:30:13.783 回答
1

db.php 包含在createConfigFiles函数执行之前。

您要么需要在createConfigFiles函数中定义变量,要么需要创建文件:

public function createConfigFile($action)
{
    if ($action == "complete")
    {
        $file_content = file_get_contents("db.php");
        $file_content .= 'define("CONFIG_DONE", "true");';
        file_put_contents("db.php", $file_content);
    }
    else
    {
        $this->db_connection = new mysqli($_POST['input_db_host'], $_POST['input_db_user'], $_POST['input_db_pass'], $_POST['input_db_name']);
        if (!$this->db_connection->connect_errno)
        {
            $file_content =    '<?php'."\n";
            $file_content .=   'define("DB_HOST", "'.$_POST['input_db_host'].'");'."\n";
            $file_content .=   'define("DB_NAME", "'.$_POST['input_db_name'].'");'."\n";
            $file_content .=   'define("DB_USER", "'.$_POST['input_db_user'].'");'."\n";
            $file_content .=   'define("DB_PASS", "'.$_POST['input_db_pass'].'");'."\n";

            file_put_contents("db.php", $file_content);
            fclose("db.php");
            define("DB_HOST", $_POST['input_db_host']);
            define("DB_NAME", $_POST['input_db_name']);
            define("DB_USER", $_POST['input_db_user']);
            define("DB_PASS", $_POST['input_db_pass']);;
            $login->messages[] = "That's it! You're now ready to kick ass at some image management!";
        }
        else
        {
            $this->errors[] = "Wrong database credentials!"; 
        }
    }

}

或者,如果 Login 永远不会使用 __construct 上的数据库,您也可以这样做:

require_once("classes/Login.php");

$login = new Login();

require_once("db.php");

两者都没有必要!

于 2013-07-03T01:29:07.913 回答