首頁 後端開發 php教程 如何在 PHP 中從外部類別存取 MySQLi:透過依賴注入克服內部伺服器錯誤

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

Oct 28, 2024 pm 02:32 PM

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-&gt;set_charset('utf8mb4');</code>
登入後複製

myapi.php:

<code class="php">class MyAPI {
    protected $db;
    
    public function __construct($db) {
        $this-&gt;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 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱門文章標籤

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

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

11個最佳PHP URL縮短腳本(免費和高級) 11個最佳PHP URL縮短腳本(免費和高級) Mar 03, 2025 am 10:49 AM

11個最佳PHP URL縮短腳本(免費和高級)

在Laravel中使用Flash會話數據 在Laravel中使用Flash會話數據 Mar 12, 2025 pm 05:08 PM

在Laravel中使用Flash會話數據

構建具有Laravel後端的React應用程序:第2部分,React 構建具有Laravel後端的React應用程序:第2部分,React Mar 04, 2025 am 09:33 AM

構建具有Laravel後端的React應用程序:第2部分,React

簡化的HTTP響應在Laravel測試中模擬了 簡化的HTTP響應在Laravel測試中模擬了 Mar 12, 2025 pm 05:09 PM

簡化的HTTP響應在Laravel測試中模擬了

php中的捲曲:如何在REST API中使用PHP捲曲擴展 php中的捲曲:如何在REST API中使用PHP捲曲擴展 Mar 14, 2025 am 11:42 AM

php中的捲曲:如何在REST API中使用PHP捲曲擴展

在Codecanyon上的12個最佳PHP聊天腳本 在Codecanyon上的12個最佳PHP聊天腳本 Mar 13, 2025 pm 12:08 PM

在Codecanyon上的12個最佳PHP聊天腳本

宣布 2025 年 PHP 形勢調查 宣布 2025 年 PHP 形勢調查 Mar 03, 2025 pm 04:20 PM

宣布 2025 年 PHP 形勢調查

Laravel中的通知 Laravel中的通知 Mar 04, 2025 am 09:22 AM

Laravel中的通知

See all articles