doujiyuan0211 2014-03-02 14:59
浏览 19
已采纳

访问另一个类中的PDO对象

I'm trying to access the PDO object within a class I've created but it throws an error:

Call to undefined method EntelDB::prepare()

Below is the code. How could I access the native PDO methods like prepare() and query()?

class DB
{
    private $dbName = '';
    private $dbUsername = '';
    private $dbPassword = '';
    static protected $instance;
    public $conn;

    protected function __construct($dbName, $dbUsername, $dbPassword)
    {
        $this->dbName = $dbName;
        $this->dbUsername = $dbUsername;
        $this->dbPassword = $dbPassword;
        $this->conn = new PDO("mysql:host=localhost;dbname=" . $this->dbName . ";charset=utf8",
            $this->dbUsername, $this->dbPassword);

        $this->conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
    }

    public static function getInstance($dbName, $dbUsername, $dbPassword)
    {
        if (!self::$instance)
        {
            self::$instance = new self($dbName, $dbUsername, $dbPassword);
        }

        return self::$instance;
    }
}


class Auth
{       
    private $loginQuery = "SELECT userIdusername,password FROM login WHERE username=? AND password=?";
    public $conn;

    function login($username, $password)
    {
        /*here's the DB class usage*/
        $this->conn = DB::getInstance("patikana", "root", "");  
        $_SESSION['user_allow'] = FALSE;
        $_SESSION['user'] = '';
        $_SESSION['userId'] = '';
        $_SESSION['loggedInTime'] = '';
        $query = $this->loginQuery;
        /*
            NOT ACCESSING PREPARE METHODS.
        */
        $stmt = $this->conn->prepare($query);
    }   
}


//instatiation and usage.
$userAuthenticate = new Auth();
$userAuthenticate->login();
  • 写回答

1条回答 默认 最新

  • douzi1991 2014-03-02 15:05
    关注

    You are using singleton pattern, but also you want to get "conn" variable as a public property in the Auth class.

    Add a constructor to the Auth class:

    public function __construct()
    {
      $this->conn = DB::getInstance()->conn;
    }
    

    In the line:

    $this->conn= DB::getInstance("patikana","root","");
    

    You are not attaching connection but the DB object instance.

    Also consider using dependency injection rather than singleton. Singleton is an antipattern hard to maintain.

    I would suggest refactoring:

    class Auth {
    
    private $loginQuery="SELECT userIdusername,password FROM login WHERE username=? AND password=?";
    private $db;
    
    function __construct(DB $db) {
      $this->db = $db;
    }
    
    function login($username, $password) {
    
        $_SESSION['user_allow']=FALSE;
        $_SESSION['user']='';
        $_SESSION['userId']='';
        $_SESSION['loggedInTime']='';
        $query = $this->loginQuery;
    
        $stmt = $this->db->conn->prepare($query);
    }   
    }
    

    Then initialize your Auth object with:

    $aut = new Auth($db);
    

    where $db is instance of your Database access class;

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 保护模式-系统加载-段寄存器