我正在创建一个旨在简单而快速的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使用量与包含整个函数所需的内存量相比
答案 0 :(得分:1)
两种方法都不比另一方好得多。你可以通过从登录函数中移除mysql连接的创建来获得更多,这样你的所有SQL查询都可以使用一个相同的连接,从而创建多个连接。