1

我不明白为什么在创建这样的对象时会出现此错误:

错误在这一行的 index.php 中:

$dbPerfiles = new DB_Functions();

错误是这样的:

PDO Connection error: invalid data source name

配置文件

<?php
define ("DB_USER","root");
define ("DB_PASS","root");
define ("DNS","mysql:host=localhost;dbname=example");
?>

DB_Connect.php

<?php
require_once 'config.php';
class DB_Connect {
    private static $_instance;

    //Connecting to database
    public function &pdo_connect() {    
        if(!self::$_instance) {
            try{
                self::$_instance = new PDO(DNS,DB_USER, DB_PASS);
                self::$_instance->setAttribute(PDO::ATTR_PERSISTENT, true);
                self::$_instance->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
            } catch (PDOException $ex) {
                die("PDO Connection error: ".$ex->getMessage()."<br/>");
            }
        }
        return self::$_instance;
    }

    private function __construct() {
    }

    private function __clone() {
    }
}
?>

DB_Functions.php

<?php
    session_start();
    require_once 'DB_Connect.php';

    class DB_Functions extends DB_Connect{

        private $dbConnect = "";

        public function __construct() {
            $this->dbConnect = $this->pdo_connect();
        }

        public function __destruct() {
            $this->dbConnect = null;
        }

        public function getDetails() {
            try {
                //sql statement

            } catch (PDOException $e) {
                echo "Error: ".$e->getMessage()."<br/>";
                return false;
            }
        }
    }
?>

索引.php

<?php 
session_start();
$max_time = 1800;
$current = time();
if(!isset($_SESSION['clientmac']['un']) ) { 
    $_SESSION['clientmac']['un'] == "";
    header('Location: index.php');
} else {
    if (!isset($_SESSION['timeLogin'])){
        $_SESSION['clientmac']['tl'] = time();
    } else {
        $session_life = $current - $_SESSION['clientmac']['tl'];    

        if ($session_life > $max_time) {
            header('Location: include/logout.php');
        } else {
            $_SESSION['clientmac']['tl'] = time();
        }
    }

    require_once 'include/DB_Functions.php';
    $dbPerfiles = new DB_Functions();  //With this line shows the error

    //code to connect to getDetails() function in DB_Functions.php and
    //retrieve some data.

?>
<!doctype html>
<html lang=en>
<!--
CODE HTML
-->
</html>
<?php
}
?>

我想连接到 DB_Functions 并连接到此文件中的 getDetails() 函数或其他函数并检索数据.. 仅此而已!

我希望我已经解释过了。

问候!!

4

2 回答 2

1

无效数据源名称等错误可能指:

  1. DSN 语法不正确(在您的情况下它看起来正确);
  2. DSN 参数不正确
    1. 主机可能不是本地主机(您的 mysql 配置可能不允许通过 TCP 或来自本地主机本身的连接,但我对此表示怀疑,因为默认允许来自本地主机的 TCP 连接);
    2. 数据库名称可能不正确(因为在您的代码中example)使我认为您可能没有创建名为 example 的数据库;
于 2012-09-01T00:47:05.900 回答
1

解决了!只有我只需要添加这一行

require_once 'include/config.php'; 

以上

require_once 'include/DB_Functions.php'; 

并且有效,但我不明白为什么?

因为在 DB_Connect.php 中是相同的这一行。

于 2012-09-02T01:12:41.980 回答