我将我们的一个客户网站转移到一家新的托管公司。
新的托管公司使用 PHP 5.3.14
我在公司的运行 PHP 5.1.6 的测试机器上测试了这个网站,一切正常。
但是,当我将站点移动到新托管公司的服务器时,它给了我以下错误:
致命错误:在第 20 行的 /var/www/html/nna_test/data/class_core/db/DAO_gate.php 中调用未定义的方法 DAOtemplate_Ex::DAOparent_Ex()
这是我的 DAO_gate.php
<?php
require_once CLASS_CORE_EX_REALDIR . 'db_extends/DAOtemplate_Ex.php';
class DAO_gate extends DAOtemplate_Ex
{
function DAO_gate( $value1="" )
{
parent::DAOparent_Ex(); ---***LINE 20***---
$this->m_tablename = "dtb_gate";
$this->m_struct = array();
$this->m_struct_foreignKey = array();
$this->m_struct_foreignKey_target = array();
// get: table struct.
$this->CDB->SetQuery( "show full columns from ". $this->m_tablename );
$this->CDB->ExecQuery();
while( $row = $this->CDB->GetRecord() ) {
$this->m_struct[] = $row;
}
$this->init();
}
.blah
.blah
.blah
}
而DAO_gate.php扩展的DAOtemplate_Ex如下
<?php
// {{{ requires
require_once CLASS_CORE_REALDIR . 'db/DAOtemplate.php';
class DAOtemplate_Ex extends DAOtemplate
{
}
?>
DAOtemplate_Ex 扩展了 DAOtemplate
<?php
require_once CLASS_CORE_EX_REALDIR . 'db_extends/DAOparent_Ex.php';
class DAOtemplate extends DAOparent_Ex
{
var $m_tablename;
var $m_struct;
var $m_struct_foreignKey;
var $m_struct_foreignKey_target;
function DAOtemplate( $value1="" )
{
parent::DAOparent_Ex();
$this->m_tablename = "";
$this->m_struct = array();
$this->m_struct_foreignKey = array();
$this->m_struct_foreignKey_target = array();
$this->CDB->SetQuery( "show full columns from ". $this->m_tablename );
$this->CDB->ExecQuery();
while( $row = $this->CDB->GetRecord() ) {
$this->m_struct[] = $row;
}
$this->init();
}
.blah
.blah
.blah
}
DAOparent_Ex :
<?php
require_once CLASS_CORE_REALDIR . 'db/DAOparent.php';
class DAOparent_Ex extends DAOparent
{
}
?>
最后是 DAOparent :
<?php
require_once CLASS_CORE_REALDIR . 'db/SC_DBFactory.php';
class DAOparent
{
var $CDB;
var $m_use_sql;
function DAOparent()
{
if( empty( $value1 ) )
{
$this->CDB = SC_DBFactory::GetInstance( DB_TYPE );
$this->CDB->SetDBType( DB_TYPE );
$this->CDB->SetHost( DB_SERVER );
$this->CDB->SetDBName( DB_NAME );
$this->CDB->SetUserName( DB_USER );
$this->CDB->SetPassword( DB_PASSWORD );
$this->CDB->SetCharaCode( DB_ENCODING );
} else {
if( is_object( $value1 ) )
{
$this->CDB = $value1;
} else {
// error:
print( "connect faild." );
die();
}
}
$this->CDB->Connect();
$this->m_use_sql = array( "select", "update", "insert", "delete", "begin", "rollback" );
$this->init();
}
function init()
{
}
.blah
.blah
.blah
}
有谁知道这个问题?
我认为这是因为空的课程。
对于发布如此长的代码,我深表歉意。