Parent的类构造函数调用错误?

时间:2016-08-05 03:02:42

标签: php constructor

我正在尝试调用父类构造函数,但它会抛出错误

Fatal error: Cannot call constructor

并且相同的代码之前工作得很好,我没有改变任何东西,但突然间不知道发生了什么,它正在抛出这个错误。

我已经在stackoverflow上阅读了一些答案,但是他们说你的父类不包含构造函数,嗯,这不是我的情况我在父类中有构造函数。这是我的代码:

class DB
{
    var $con;

    public function __construct()
    {
        require_once 'configs/dbconfig.php';
        $this->connect();
    }

    function connect()
    {
        try{
            $this->con = new PDO('mysql:host='.DB_HOST.';dbname='.DB_NAME,DB_USER,DB_PASS);
            $this->con->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);
        }catch(PDOException $ex) {
            echo $ex->getMessage();
        }
    }
}

然后我有一个类Posts,它扩展DB并调用DB的构造函数。

class Posts extends DB
{
    var $user_id;

    public function __construct($user_id)
    {
        parent::__construct();
        $this->user_id = $user_id;
    }

    function get_posts($search,$pages,$since_id=0,$max_id=false,$count=20,$status='active')
    {
        $extra = '';
        if($search) $extra .= " AND text LIKE CONCAT('%',:search,'%')";
        if(!empty($pages)) $extra .= " AND page IN('".implode("','", $pages)."')";
        if(!empty($status) && $status != 'all') $extra .= " AND status=:status";

        $max_id = ($max_id) ? $max_id : time();

        $sqlCommand = "SELECT id,pid,text,media,media_url,type,name,u_id,username,user_profile_url,user_photo_url,post_url,date,status,source,page_id FROM ".POSTS." WHERE date>=:since_id AND date<=:max_id".$extra." AND user_id=:user_id ORDER BY date DESC LIMIT $count";
        $params = array(':since_id'=>$since_id,':max_id'=>$max_id,':user_id'=>$this->user_id);
        if($search) $params[':search'] = $search;
        if($status && $status != 'all') $params[':status'] = $status;

        $posts = $this->fetch($sqlCommand,$params);
        return $posts;
    }
}

3 个答案:

答案 0 :(得分:1)

这是你的php版本,它必须已经更改,请检查php的版本并尝试更新。

答案 1 :(得分:-1)

我认为这是一个已知的PHP错误(看here),尝试在DB中创建一个函数,返回一个新的DB(通过调用构造函数)并在{{1调用你创建的这个函数。

答案 2 :(得分:-2)

嗯,也许这是一个基本的愚蠢回答,但你是否尝试过要求&#39;?