2017-09-26 10 views
-2

Learning façon PHP POO:AOP ne peut pas être convertie en chaîne php

base de données passe objet de classe autre classe i reçu ce message « Catchable erreur fatale: Objet AOP de classe ne peut pas être convertie en chaîne », quant à lui la code fonctionne bien si je commente cette ligne '//$imageobj= new image($dbobj);'?

Mise à jour: une fois que j'ajouter cette ligne à $this->dbconn=null;getConnection() fonction db.class.php avant try {}. tout fonctionne bien !!!

index.php

<?php 
include "./classes/db.class.php"; 
include "./classes/image.class.php"; 

$dbobj= new db(); 
$imageobj= new image($dbobj); 

$page_title="Shopping Center !"; 
include './template/header.php'; 

$dbobj->getConnection(); 

include './template/footer.php'; 

db.class.php

class db { 
    private $host; 
    private $dbname; 
    private $username; 
    private $password; 
    private $dbconn; 
    private $status; 

    public function __construct() { 
     // the require paramaters to start db connnection 
     $this->host = '127.0.0.1'; 
     $this->dbname = 'shop_carta'; 
     $this->username = 'root'; 
     $this->password = ''; 
     $this->status = 0; 
     //$this->dbconn = null; 
    } 

    public function getConnection() { 
     try { 
      $this->dbconn = new PDO("mysql:host=$this->host;dbname=$this->dbconn", $this->username, $this->password); 
      if (!is_null($this->dbconn)) { 

       $this->status = $this->dbconn->getAttribute(PDO::ATTR_CONNECTION_STATUS); 
       $this->dbconn->setAttribute(PDO::ATTR_DEFAULT_FETCH_MODE, PDO::FETCH_ASSOC); 
       $this->dbconn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); 

       return $this->dbconn; 
      } else { 
       echo "<div class='alert alert-danger'>" 
       . " Our server Busy Now try again later.. </div></br>"; 
       return false; 
      } 
     } catch (PDOException $ex) { 
       return false; 
     }}} 

image.class.php this class receive the $dbobject try to $dbobject->getConncetion() and set retrieve

class image { 
    private $table_name = 'product_images'; 
    private $dbconn; 
    public $id; 
    public $name; 

    public function __construct($dbobj) { 
     $this->dbconn = $dbobj->getConnection(); 
     }}     

Error message once you pass $dbobj to image class

once you commit line $imageobj= new image($dbobj); in index.php

Attribuer dbconn à null résoudre: Erreur fatale capturable: L'objet de classe PDO n'a pas pu être converti en chaîne. Toute suggestion POURQUOI? enter image description here

+1

montrent le code de la classe d'image - semble le constructeur de 'image' n'accepte uniquement les chaînes, mais vous êtes passer un objet 'db' entier –

+0

class image { private $ table_name = 'product_images'; private $ dbconn; public $ id; public $ name; fonction publique __construct ($ dbobj) { $ this-> dbconn = $ dbobj-> getConnection(); }} – Mvrk

Répondre

1

La question se trouve ici:

"mysql:host=$this->host;dbname=$this->dbconn" 

nombase doit être un nom de base de données. Vous fournissez une propriété qui (avant d'avoir ajouté $ this-> dbconn = null) n'existe pas, c'est pourquoi vous obtenez une erreur. Ajouter $ this-> dbconn = null, empêche le fatal sur la propriété non existante, mais vous fournissez toujours un nom de base de données vide.

Vous devez le réparer en le remplaçant par $ this-> dbname, comme ceci:

"mysql:host=$this->host;dbname=$this->dbname" 
+0

C'était stupide erreur se sent si bête: /. Merci @Erik. – Mvrk