」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 如何修復 PHP 透過 SSH 連接 MySQL 時的 mysqli_connect() 參數問題?

如何修復 PHP 透過 SSH 連接 MySQL 時的 mysqli_connect() 參數問題?

發佈於2024-11-06
瀏覽:648

How to Fix mysqli_connect() Parameter Issue When Connecting to MySQL over SSH with PHP?

在 PHP 中透過 SSH 連接到 MySQL 伺服器

使用 PHP 函數透過 SSH 建立與遠端 Linux 電腦上託管的 MySQL 資料庫的連接可能具有挑戰性。使用提供的程式碼時,可能會出現錯誤「mysqli_connect()期望參數6為字串,給定資源」。

理解問題

程式碼嘗試使用mysqli_connect()函數來透過 SSH 隧道連接到資料庫。但是,mysqli_connect() 函數需要一個字串作為第六個參數(表示隧道),而 ssh2_tunnel() 函數傳回一個資源。

使用 SSH Tunnel 解決問題

要解決解決此問題,請設定至 MySQL 資料庫伺服器的 SSH 隧道。一種有效的方法是使用 Jumpbox 代理來增強安全性。此方法涉及使用 SSH 用戶端建立本機連接埠轉送隧道,從而有效地在本機電腦和資料庫伺服器之間建立安全通道。

逐步指南

使用命令列工具(SSH 隧道設定):

  1. 從本地端執行下列SSH 指令:
  2. ]
ssh -fNg -L 3307:10.3.1.55:3306 [email protected] 
  • 將「3307」替換為您首選的本機連接埠號碼。
  • 將「10.3.1.55:3306」替換為 IP 位址和連接埠
  • 將「[email protected]」替換為您的 Jumpbox 登入憑證。

連接到資料庫:

  1. 在PHP 腳本中,使用mysqli_connect() 建立資料庫連線:
$mysqli = mysqli_connect("127.0.0.1:3307", "DB_USERNAME", "DB_PASSWORD", "dbname");
  • 使用SSH 隧道設定中指定的本地連接埠(本範例中為3307)。

其他注意事項:

  • 使用支援 SSH 隧道的 GUI MySQL 用戶端(例如 Visual Studio Code)可以簡化設定流程。
  • 私鑰認證可以增強安全性。使用 SSH 命令中的“-i”開關指定您的私鑰路徑。
  • 透過 Jumpbox/Bastion 主機的隧道流量可緩解直接資料庫存取漏洞。
版本聲明 本文轉載於:1729520899如有侵犯,請洽[email protected]刪除
最新教學 更多>
  • Go ost 量子密碼網路伺服器
    Go ost 量子密碼網路伺服器
    Golang 1.23 將後量子密碼學引入 Go 標準庫。它非常棒且易於使用。 這篇文章「Go 1.23 中的後量子加密 Web 伺服器」包含一些程式碼範例和後量子加密的背景.. 我總是很好奇我正在使用哪個 TLS 密碼套件和曲線,因此我添加了一個片段來執行此操作(使用反射) 您認為還需要更多的例...
    程式設計 發佈於2024-11-06
  • Js電子表格組件
    Js電子表格組件
    我經常使用的一件事是我們用來組織資料的 Excel 表格。 Jspreadsheet 執行的操作非常相似,但直接在瀏覽器中執行。您無需安裝任何東西,只需打開並使用它即可。對於任何需要以簡單實用的方式組織資訊的人來說,它都是完美的選擇。 簡單易用: 如果您曾經使用過 Excel,您會感到賓至如歸。介...
    程式設計 發佈於2024-11-06
  • 掌握 MySQL:每個開發人員都應該監控的關鍵效能指標
    掌握 MySQL:每個開發人員都應該監控的關鍵效能指標
    监控 MySQL 性能指标和管理数据库并不困难。是的,你没听错。有了适当的监控策略和工具,您终于可以退居二线了。 RED 方法与 Releem 强大的监控功能和易于应用的配置建议相结合,可以为您完成繁重的工作。 红色方法简介 RED方法传统上用于监控Web应用程序和服务的性能,但也可...
    程式設計 發佈於2024-11-06
  • 答:C++中如何產生隨機數?
    答:C++中如何產生隨機數?
    這是一個很好的答案! 回覆回覆:如何在C中產生隨機數? 2012 年 11 月 18 日 ...
    程式設計 發佈於2024-11-06
  • 如何在 JavaScript 中對 HTML 實體進行編碼以便在 CMS 中正確顯示?
    如何在 JavaScript 中對 HTML 實體進行編碼以便在 CMS 中正確顯示?
    在JavaScript 中編碼HTML 實體將內容輸入內容管理系統(CMS) 時,處理® 等特殊字元至關重要確保跨瀏覽器正確顯示。為了解決這個問題,可以使用 JavaScript 來定位這些符號並將其轉換為適當的 HTML 實體。 使用正規表示式,可以透過將特定字元範圍替換為對應的 HTML 實體來...
    程式設計 發佈於2024-11-06
  • 為什麼「float: right」會顛倒 HTML 中的 Span 順序?
    為什麼「float: right」會顛倒 HTML 中的 Span 順序?
    Float:跨度的右反轉順序給定 HTML 標記:<div> <span class="label"><a href="/index/1">Bookmix Offline</a></span>...
    程式設計 發佈於2024-11-06
  • Python 字典如何保持程式碼乾淨、乾燥
    Python 字典如何保持程式碼乾淨、乾燥
    Python 字典和 DRY 原则:初学者快速指南 嘿! ?如果您正在深入研究 Python 编程,您可能偶然发现了字典,并且可能想知道“Python 中的字典到底是什么?它如何帮助我更智能地编写代码?”不用担心,让我们用一种超级简单的方式来分解它。 Python ...
    程式設計 發佈於2024-11-06
  • 使用 Django、Twilio 和 Pinata 建立安全的匿名回饋系統
    使用 Django、Twilio 和 Pinata 建立安全的匿名回饋系統
    在本指南中,我将引导您使用 Django、用于短信通知的 Twilio、用于安全媒体上传的 Pinata 以及用于响应式样式的 TailwindCSS 构建安全匿名反馈系统。在本教程结束时,您将拥有一个功能齐全的反馈系统,用户可以在其中提交反馈、选择上传媒体以及接收短信通知 - 所有这些都考虑到安全...
    程式設計 發佈於2024-11-06
  • 為什麼 Tkinter Entry 的 get 函數不回傳任何內容?
    為什麼 Tkinter Entry 的 get 函數不回傳任何內容?
    Tkinter Entry 的get 函數沒有產生任何結果:綜合解釋當嘗試使用get() 從Tkinter Entry 小部件檢索用戶輸入時函數時,您可能會遇到空返回值。這個看似令人困惑的問題源自於 Tkinter 的非同步特性和函數執行的順序。 在提供的程式碼片段中,您嘗試在建立 Entry 後立...
    程式設計 發佈於2024-11-06
  • 使用 NodeJs 開始使用 RabbitMq
    使用 NodeJs 開始使用 RabbitMq
    RabbitMq簡介 RabbitMq 是一個訊息代理,允許在不同服務之間發送和接收訊息。它是一個實作高階訊息佇列協定(AMQP)的訊息代理程式。用 Erlang 程式語言寫成。 安裝 RabbitMq RabbitMq 可以使用各自的套件管理器安裝在不同的作業系統上。 Rabbi...
    程式設計 發佈於2024-11-06
  • 讓網路更加互聯
    讓網路更加互聯
    讓網路更互聯 - Infometka 如何解決「隱形網站」問題 身為 Web 開發人員和 ???️??????️ 的創建者,我一直熱衷於解決現實世界的問題。今天,我想分享我開發的一個解決方案,我相信它可以為無數網站所有者帶來重大改變,並在某種程度上使互聯網成為一個更加互聯的地方。 ...
    程式設計 發佈於2024-11-06
  • 使用 React 建置 Loop Studio
    使用 React 建置 Loop Studio
    介绍 Loop Studio 是一个沉浸式网站,旨在展示各种虚拟现实 (VR) 项目。使用 React,我们可以有效地管理和渲染不同的组件,以构建有凝聚力和交互式的用户体验。该项目采用简洁的设计,带有导航标题、详细的 VR 部分、创作画廊以及带有社交媒体链接的页脚。 ...
    程式設計 發佈於2024-11-06
  • 如何解決用PHP在CURL中傳送多維數組時出現「陣列到字串轉換」錯誤?
    如何解決用PHP在CURL中傳送多維數組時出現「陣列到字串轉換」錯誤?
    透過CURL 和PHP 發送多維數組使用CURL 發布包含多維數組的表單資料時,遇到「數組到字串轉換」錯誤是一個常見問題。當嘗試使用包含陣列的陣列設定 CURLOPT_POSTFIELDS 時會發生這種情況。 由於 Content-Type 標頭必須是 multipart/form-data 以方便...
    程式設計 發佈於2024-11-06
  • 如何在 Selenium 中使用 \"span:contains(\'String\')\" 解決 InvalidSelectorException?
    如何在 Selenium 中使用 \"span:contains(\'String\')\" 解決 InvalidSelectorException?
    Selenium 中的Invalid SelectorException with "span:contains('String')"在Firefox 中使用Python 中的Selenium 時,嘗試使用CSS 選擇器「span:contains('Co...
    程式設計 發佈於2024-11-06
  • 如何將 HTML 附加到容器元素而不出現 InnerHTML 陷阱?
    如何將 HTML 附加到容器元素而不出現 InnerHTML 陷阱?
    在沒有innerHTML的情況下將HTML附加到容器元素重新訪問當前的問題是如何將HTML附加到容器元素,同時避免限制以及使用innerHTML屬性的陷阱。正如OP正確指出的那樣,innerHTML由於其替換現有內容的行為,可能會破壞嵌入媒體等動態元素。 幸運的是,有一個替代方案可以克服這些問題:i...
    程式設計 發佈於2024-11-06

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3