仅在登录过程中连接其他数据库


Connect a different database on the log-in process only

我正在编写的代码有点令人困惑,因为我没有编写这个代码。但我想做的是从不同的数据库获取登录信息。我不能只修改数据库连接的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,并仅在登录页面上连接到该数据库?

您的一些代码或结构会有所帮助。

函数设置活动mysql数据库。

语法

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 ...');

还要转义查询中的变量:)