包括未使用的全功能或许多包括

时间:2012-02-21 20:40:20

标签: php memory-management login cpu-usage

我正在创建一个旨在简单而快速的PHP授权框架。我的问题很简单我希望只有一个包含需要使用它,但是当只有一个包含它可能会加载不必要的功能。所以我的问题是哪个更好,包括导致使用更多内存的所有函数,或者包含一个文件,该文件具有包含该函数的函数,从而导致更少的不必要的函数,但是它会占用更多的CPU?

例如我的登录功能如下所示:

function login ($submit ='login', $user = 'user', $pass = 'pass') {
    if ($_POST[$submit]){

        $user = $_POST[$user];
    $pass = $_POST[$pass];

    if ($user && $pass){ //if user and pass is enterered

            require("auth_vars.php"); //require MySQL conection settings
            mysql_connect($auth_mysql_server, $auth_mysql_user, $auth_mysql_pass); //connect to MySQL
        mysql_select_db($auth_mysql_db); // select MySQL database

            $pass = md5($pass); // hash password

            $query = mysql_query("SELECT * FROM $auth_mysql_table WHERE user='$user'"); // run query
            $numrows = mysql_num_rows($query);

            if ($numrows == 1){ //check if user exists
                $row = mysql_fetch_assoc ($query);
                $dbid = $row[$auth_mysql_id_row];
                    $dbuser = $row[$auth_mysql_user_row];
                    $dbpass = $row[$auth_mysql_pass_row];

                    if ($pass == $dbpass){ // if password is equal to the one in the database start session
                        //set session information
                        $_SESSION['userid'] = $dbid;
                        $_SESSION['username'] = $dbuser;


                        header("Location:$auth_path_loggedin"); // goto logged in page

                    }
                    else return (3);
            }
            else return (2);

            mysql_close(); // close MySql connection
        }
        else return (1);
}else {
    // If the user clicks the "Log Out" link.
    if(isset($_GET['status']) && $_GET['status'] == 'loggedout') {
        logout();//logout
        return 4;
        //else if the user is denied
    }else if(isset($_GET['status']) && $_GET['status'] == 'denied') {
        logout(); //to keep it clean in case of errors
        return 5;
    }
}}

现在如果不需要登录功能,更好可以做到这一点:

function login ($submit ='login', $user = 'user', $pass = 'pass') {
    include ("myloginfunction.php");
    login_function($submit, $user, $pass);
}

或者它会使用多少不必要的CPU使用量与包含整个函数所需的内存量相比

1 个答案:

答案 0 :(得分:1)

两种方法都不比另一方好得多。你可以通过从登录函数中移除mysql连接的创建来获得更多,这样你的所有SQL查询都可以使用一个相同的连接,从而创建多个连接。