如何在 PHP 中從外部類別存取 MySQLi:透過依賴注入克服內部伺服器錯誤

DDD
發布: 2024-10-28 14:32:02
原創
714 人瀏覽過

How to Access MySQLi from External Classes in PHP: Overcoming Internal Server Errors with Dependency Injection

在PHP 中從外部類別使用MySQL

從PHP 5.6 遷移到7.0,並進行對應的資料庫調整,從sqlSql 到sqlSql 到sqlSql已經揭示了某些挑戰。在這裡,我們將深入研究根本問題並提供替代解決方案。

理解結構

首先,您設計了一個具有私有屬性和建構子的資料庫類別建立連線。但是,此設定會在從其他類別存取時造成斷開連線。

其次,您有一個旨在與資料庫互動的 API 類,但它在其建構函式中使用單獨的新實例化來進行資料庫連接。

錯誤根源:內部不一致

當您從 API 類別引用 $this->db->conn 時,它會檢索 null,從而導致內部伺服器錯誤。發生這種情況是因為 $this->db 僅在物件建立時初始化,並且它不保留任何連接資料。

建議的解決方案:依賴注入

相反每個類別的單獨實例化,請考慮依賴注入。操作方法如下:

  1. 使用必要的連線設定程式碼建立一個獨立的資料庫類別。
  2. 將此資料庫物件的實例作為建構子參數傳遞給任何需要資料庫存取的類別。

透過遵循這些原則,您可以在 PHP 應用程式中跨多個類別有效地利用 MySQLi。

範例實作

資料庫.php:

<code class="php">$db = new mysqli("localhost", "DBUserName", "UserPassword", "SelectedDB");
$db->set_charset('utf8mb4');</code>
登入後複製

myapi.php:

<code class="php">class MyAPI {
    protected $db;
    
    public function __construct($db) {
        $this->db = $db;
    }
    
    // ... Rest of your code
}</code>
登入後複製

app.php:

<code class="php">require 'database.php';
require 'myapi.php';

$api = new MyAPI($db);
// Utilize the API as intended</code>
登入後複製
這種重組可確保整個應用程式對資料庫資源的存取一致,從而減少您遇到的內部伺服器錯誤。

以上是如何在 PHP 中從外部類別存取 MySQLi:透過依賴注入克服內部伺服器錯誤的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!