1

我有一个 PHP 类——一个通用的 ODBC 数据库接口。虽然方法永远不会改变(因为它使用 PDO),但连接字符串会。为了避免让用户手动传递整个连接字符串或指定要放入连接字符串的 ODBC 驱动程序,我扩展了该类并创建了一个 SQL Server 特定版本。

通用 PDO ODBC 驱动程序

class PDO_ODBC implements DBDriver{
    private $driver;
    private $connection_string;

    public function connect(){
        if(!$this->driver || !$this->connection_string){
            throw new \Exception("Invalid connection string or database driver.");
        }
    }
}

SQL Server 特定版本

class PDO_ODBC_SQL_Server extends PDO_ODBC{
    public function __construct(){
        $this->driver = 'SQL Server';
        $this->connection_string = 'odbc:Driver={[Driver]};Server=[Host];Database=[DBName];Uid=[Username];Pwd=[Password]';
    }
}

问题是,当我创建一个新PDO_ODBC_SQL_Server对象并调用connect()时,抛出异常是因为$this->driver并且$this->connection_string不存在。但这怎么可能呢?如果我使用print_r,我会看到这两个属性。需要注意的一点是,print_r 它还显示了驱动程序和连接字符串之外的所有属性的类的命名空间,如下所示:http: //pastebin.com/qh40eDpa。实际上,命名空间下有连接字符串和驱动的独立变量。

如何解决此问题并防止引发异常,同时仍然能够通过扩展基本 ODBC 类来使用类似的设计模式?如果没有,那么替代方法是允许开发人员传入驱动程序和连接字符串......

请注意,为简洁起见,我在上面的代码示例中省略了大部分私有变量。这两个类都位于单独的文件中,并且位于命名空间下Lib\Database

4

1 回答 1

1

protected如果您想让它们保持私有,请制作类属性或制作 getter 和 setter。私有属性只能从声明它们的类访问,不能从派生类访问。

class PDO_ODBC implements DBDriver{
    protected $driver;
    protected $connection_string;

    public function connect(){
        if(!$this->driver || !$this->connection_string){
            throw new \Exception("Invalid connection string or database driver.");
        }
    }
}

http://php.net/manual/en/language.oop5.visibility.php#language.oop5.visibility-members

于 2012-12-04T23:20:15.287 回答