我正在编写的代码有点令人困惑,因为我没有编写这个代码。但我想做的是从不同的数据库获取登录信息。我不能只修改数据库连接的config.php,因为它会扰乱整个系统。我试着通过在mysql_connect上存储不同的变量来连接两个数据库。但在这种情况下,这有点令人困惑。有没有其他方法可以在登录过程中只更改数据库连接一次?
login.php(提交登录信息后的php文件)
include("inc/config.php");
$connection = mysql_connect($hostname, $user, $pass) or die ("Unable to connect!");
$query = "SELECT * FROM clients WHERE name = '$name' AND password = '$password'";
$result = mysql_db_query($database, $query, $connection);
$date_in = date("Y-m-d");
$time_in = date("H:i:s");
$client_accesslogin = $name;
if (mysql_num_rows($result) == 1)
{
session_start();
session_register('time_in');
session_register('date_in');
session_register('client_accesslogin');
session_register('remoteaddr');
$_SESSION['time_in']=$time_in;
$_SESSION['date_in']=$date_in;
$remoteaddr = $_SERVER['REMOTE_ADDR'];
$ipaddr = $_SERVER['REMOTE_ADDR'];
$client_accesslogin = $_SESSION['client_accesslogin'];
session_register("client_id");
session_register("client_name");
session_register("client_email");
session_register("client_company");
list($clientid, $name,$first_name,$last_name, $pass, $email, $company) = mysql_fetch_row($result);
$client_id = $clientid;
$client_name = $name;
$fname=$first_name;
$lname=$last_name;
$client_email = $email;
$client_company = $company;
$cisloggedin = 'Yes';
session_register("cisloggedin");
session_register("fname");
session_register("lname");
header("Location: menu.php");
mysql_free_result ($result);
mysql_close($connection);
}
$connection = mysql_connect($hostname, $user, $pass) or die ("Unable to connect!");
$query = "SELECT * FROM admins WHERE name = '$name' AND password = '$password'";
$result = mysql_db_query($database, $query, $connection);
$date_in = date("Y-m-d");
$time_in = date("H:i:s");
$accesslogin = $name;
if (mysql_num_rows($result) == 1)
{
session_start();
session_register('time_in');
session_register('date_in');
session_register('accesslogin');
session_register('remoteaddr');
$_SESSION['time_in']=$time_in;
$_SESSION['date_in']=$date_in;
$remoteaddr = $_SERVER['REMOTE_ADDR'];
$ipaddr = $_SERVER['REMOTE_ADDR'];
$accesslogin = $_SESSION['accesslogin'];
session_register("client_id");
session_register("client_name");
session_register("client_email");
list($clientid, $name, $pass, $email) = mysql_fetch_row($result);
$client_id = $clientid;
$client_name = $name;
$client_name = "admin";
$client_email = $email;
$isloggedin = 'Yes';
session_register("isloggedin");
header("Location: menu.php");
mysql_free_result ($result);
mysql_close($connection);
}
else
{
mysql_free_result ($result);
mysql_close($connection);
header("Location: index.php");
exit;
}
?>
这很管用。但是,如果我删除包含的config.php,只添加连接:
$database = "invoices";
$user = "root";
$pass = "";
$hostname = "localhost";
它不登录。我不明白。inc/config.php有一些关于连接的代码,但为什么我不能在不使用include的情况下添加连接本身?
我所做的假设是有一个用于登录处理的专用页面?
在这种情况下,您可以创建一个新的config.php,并仅在登录页面上连接到该数据库?
您的一些代码或结构会有所帮助。
语法
bool mysql_select_db ( string database_name [, resource link_identifier])
mysql_select_db()尝试选择与指定链接标识符关联的服务器上的现有数据库。
成功时返回TRUE,失败时返回FALSE。
我们可以使用mysql_select_db函数在mysql服务器中选择数据库。mysql_select_db()选择服务器上与指定链接标识符关联的当前活动数据库。如果未指定链接标识符,则假定为最后打开的链接。如果没有打开链接,函数将尝试设置链接,就好像调用mysql_connect()时没有参数一样。
制作了一个函数来连接到数据库,同时关闭连接。
function connect(user, pass, location)
function disconnect()
然后连接到第一个数据库,进行操作。关闭它,然后打开与另一个数据库的新连接,并执行您的操作。
如果你想一次维护2个连接,你可以将你的实例保存到变量
并执行:
mysqli_select_db($instance1, 'SELECT ...');
mysqli_select_db($instance2, 'SELECT ...');
还要转义查询中的变量:)