Appel à une fonction membre préparer () sur un PDO de PHP non-objet

voix
0

Pouvez-vous m'aider? Je reçois un peu de problèmes avec mon script.

database.php

class Database {

    protected $host = localhost;
    protected $dbname = phppdo;
    protected $user = root;
    protected $pass = ;
    protected $DBH;

    public function __construct() {
        try {
            $this->DBH = new PDO(mysql:host=$this->host;dbname=$this->dbname, $this->user, $this->pass);
        }
        catch (PDOException $e) {
            die($e->getMessage());
        }
        return $this->DBH;
    }
}

user.php

date_default_timezone_set('America/Sao_Paulo');
include 'database.php';
class User extends Database {

    private $name;
    private $email;
    private $date;

    function __construct($name, $email) {
        $this->$name = $name;
        $this->$email = $email;
    }

    public function insert() {
        $STH = $this->DBH->prepare(INSERT INTO `phppdo` VALUES(NULL, :username, :email, UNIX_TIMESTAMP()));
        $STH->execute(array(
            ':name' => $name,
            ':emal' => $email,
        ));
    }
}

if(isset($_POST['submit'])) {
    $x = new User($_POST['name'], $_POST['email']);
    $x->insert();
}

Le script ne fonctionne pas! Je reçois Call to a member function prepare() on a non-object on line 16= $STH = $this->DBH->prepare(INSERT INTOphppdoVALUES(NULL, :username, :email, UNIX_TIMESTAMP()));

Je ne sais pas pourquoi ça se passe ... Pouvez-vous me aider? Je vous remercie!!

Créé 20/10/2018 à 03:33
source utilisateur
Dans d'autres langues...                            


1 réponses

voix
0

Faites votre classe utilisateur comme ci-dessous:

class User extends Database {

private $name;
private $email;
private $date;

function __construct($name, $email) {

    $this->name = $name;
    $this->email = $email;
    parent::__construct();
}

public function insert() {

    $STH = $this->DBH->prepare("INSERT INTO `phppdo` VALUES(NULL, :name, :email, UNIX_TIMESTAMP())");
    $STH->execute(array(
        ':name' => $this->name,
        ':email' => $this->email,
    ));
}
}
Créé 20/10/2018 à 03:51
source utilisateur

Cookies help us deliver our services. By using our services, you agree to our use of cookies. Learn more