1

我们试图了解在多个自定义类中使用 mysqli/其他类的最佳方式,这样我们就不会每次都实例化一个新对象。

下面的代码是最好/正确的方法吗?

这些功能只是示例。

谢谢 :)

<?php  
class Base {

  public function __get($name) {
    if($name == 'db'){
      $db = new mysqli('**', '*s', '*', '*');
      $this->db = $db;
      return $db;
    }

  if($name == 'blowfish'){       
    $blowfish = new PasswordHash(8, true);
    $this->blowfish = $blowfish;
    return $blowfish;
  }
  }

}

class A extends Base {

  public function validate($username, $password) {

    $query = $this->db->query("SELECT * FROM users");

    return $query->num_rows;
  }

  public function password($password)
  {
    return $this->blowfish->HashPassword($password);
  }

}

class PasswordHash {
  public function __construct($iteration_count_log2, $portable_hashes) { }

  public function HashPassword($password) {
    return $password;
  }

}

$a = new A;

echo $a->validate('test','test'); // returns number rows count as expected
echo $a->password('password123'); // returns password123 as expected
?>
4

1 回答 1

1

您可能/应该对依赖注入更感兴趣,而不是创建 Base|A 和 MySQL 数据库的紧密耦合。

于 2013-06-26T10:42:46.570 回答