如何在 PHP 中從外部類別存取 MySQLi:透過依賴注入克服內部伺服器錯誤
Oct 28, 2024 pm 02:32 PM在PHP 中從外部類別使用MySQL
從PHP 5.6 遷移到7.0,並進行對應的資料庫調整,從sqlSql 到sqlSql 到sqlSql已經揭示了某些挑戰。在這裡,我們將深入研究根本問題並提供替代解決方案。
理解結構
首先,您設計了一個具有私有屬性和建構子的資料庫類別建立連線。但是,此設定會在從其他類別存取時造成斷開連線。
其次,您有一個旨在與資料庫互動的 API 類,但它在其建構函式中使用單獨的新實例化來進行資料庫連接。
錯誤根源:內部不一致
當您從 API 類別引用 $this->db->conn 時,它會檢索 null,從而導致內部伺服器錯誤。發生這種情況是因為 $this->db 僅在物件建立時初始化,並且它不保留任何連接資料。
建議的解決方案:依賴注入
相反每個類別的單獨實例化,請考慮依賴注入。操作方法如下:
- 使用必要的連線設定程式碼建立一個獨立的資料庫類別。
- 將此資料庫物件的實例作為建構子參數傳遞給任何需要資料庫存取的類別。
透過遵循這些原則,您可以在 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中文網其他相關文章!
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱門文章
倉庫:如何復興隊友
3 週前
By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 週前
By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前
By 尊渡假赌尊渡假赌尊渡假赌
擊敗分裂小說需要多長時間?
3 週前
By DDD
公眾號網頁更新緩存難題:如何避免版本更新後舊緩存影響用戶體驗?
3 週前
By 王林

熱門文章
倉庫:如何復興隊友
3 週前
By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 週前
By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前
By 尊渡假赌尊渡假赌尊渡假赌
擊敗分裂小說需要多長時間?
3 週前
By DDD
公眾號網頁更新緩存難題:如何避免版本更新後舊緩存影響用戶體驗?
3 週前
By 王林

熱門文章標籤

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)