Вопрос по oop, mysqli, mysql, php – Как получить доступ к соединению mysqli в другом классе на другой странице?

2

Как я могу открыть соединение с базой данных в пользовательском классе, где я могу выполнять операции с базой данных? и зачем нужно определять встроенные созданные функции в классе DBConnection .. ????

Я создал

  1. db.php
  2. user.php
  3. result.php

in db.php

class DBConnection  
{       
  protected $mysqli;
  private  $db_host="127.0.0.1";
  private  $db_name="test";
  private  $db_username="root";
  private  $db_password="";

  public function __construct()
    {
        $this->mysqli=new mysqli($this->db_host,$this->db_username,
                $this->  db_password,$this->db_name) or die($this->mysqli->error);

         return $this->mysqli;
    }

public function query($query)  // why i need to creat this function
     {
    return $this->mysqli->query($query);
     }

public function real_escape_string($str)
 {
    return $this->mysqli->real_escape_string();
 }


   function __destruct(){
     //Close the Connection
     $this->mysqli->close();
    }
}
?>

in User.php

<?php
  require "db.php"; 

  class User {  

  public function __construct($conn)
{
    $this->mysqli=$conn;

}

   public function addUser($name,$username,$email,$pwd)
   {
     $query="  ";

     $res=$this->mysqli->query($query);

  //pls chek the query function in DBConnection,what is the need to define query               >       function in DBConnection ?

    return $res;
    }
   }    
?>

in result.php

    <?php

      require "user.php";

      $conn=new DBConnection();

      if(isset($_POST['submit']))
  {
 $name = $conn->real_escape_string(trim(strip_tags($_POST['name'])));
   $username =  $conn->real_escape_string(trim(strip_tags($_POST['username'])));
   $email =     $conn->real_escape_string(trim(strip_tags($_POST['email'])));
   $password    = $conn->real_escape_string(trim(strip_tags($_POST['pass'])));
//echo $name."".$username."".$email."".$password;
  $uObj=new User($conn);
  $uObj->addUser($name,$username,$email,$password);


echo " hi your name is <I>".$name."</I> and your email ID is <I>".$email."</I>";
        }


?>
Неясно, гдеUser класс получает свое->mysqli собственность от. ЯвляетсяUser подклассDBConnection? Ja͢ck

Ваш Ответ

1   ответ
1

ВашDBConnection Классу потребуется дополнительный метод:

public function getLink()
{
    return $this->mysqli;
}

Кажется, что ваш оригиналUser класс был подклассомDBConnection, так какmysqli собственность наDBConnection являетсяprotected а такжеUser класс имеетparent::__construct() вызов.

Лучше использовать внедрение зависимостей, поэтому вашиUser класс получит соединение с базой данных через конструктор:

public function __construct(DBConnection $db)
{
    $this->mysqli = $db->getLink();
}

Затем из вашего кода вы можете запустить:

$db = new DBConnection;
$uObj = new User($db);
ни один пользователь не является подклассом DBConnection. mkat
@ user1055480 обновил ответ еще раз, пожалуйста, проверьте.
Другой способ заключается в том, что & lt; pre & gt; передать объект БД при создании объекта пользователя$uOBj=new User(new DBCOnnection); это правильный способ получить соединение .. ??? & lt; / pre & gt; mkat
но для выполнения операции вставки я не могу запустить запрос внутри класса пользователя в функции вставки. & gt; addUser ($ name, $ username, $ email, $ pwd) & gt; {& gt; & GT; $ Запроса = & Quot; & Quot ;; & GT; & GT; $ Рез = $ этом- & GT; mysqli- & GT; запрос ($ запроса); & GT; // я хочу запустить запрос вставки здесь .... но я не могу этого сделать & gt; вернуть $ res; & GT; } mkat
@ user1055480 Ваш вопрос неопределенный, но я обновил свой ответ, надеюсь, это поможет.

Похожие вопросы