首页 > 数据库 > mysql教程 > 如何在 PHP 中通过 SSH 隧道安全连接到 MySQL 数据库?

如何在 PHP 中通过 SSH 隧道安全连接到 MySQL 数据库?

Patricia Arquette
发布: 2024-11-29 00:52:11
原创
770 人浏览过

How to Securely Connect to a MySQL Database via SSH Tunnel in PHP?

在 PHP 中通过 SSH 连接到 MySQL

背景:数据库连接的 SSH 隧道

通过 SSH 连接到远程数据库提供了安全高效的方式数据访问方式。 SSH 充当传输 MySQL 查询的加密通道,保护敏感信息免遭拦截。

SSH 隧道配置

要建立 SSH 隧道,请使用带 -L 开关的 ssh 命令指定本地端口转发。此交换机通过 SSH 将流量从指定的本地端口重定向到数据库服务器的远程 IP 地址和端口。

例如,以下命令设置从本地端口 3307 到 10.3.1.55 的数据库服务器的隧道: 3306 通过 ssh-jumpbox.com 上的 SSH 代理:

ssh -fNg -L 3307:10.3.1.55:3306 [email protected] 
登录后复制

MySQL 连接通过隧道

现在隧道已建立,配置您的 PHP 应用程序以通过本地端口连接到数据库。这涉及到在 MySQL 连接函数中指定“127.0.0.1:3307”作为主机参数,如下例所示:

$smysql = mysql_connect("127.0.0.1:3307", "dbuser", "passphrase");
登录后复制

此连接字符串指向 MySQL 使用本地端口 3307,这将通过 SSH 隧道转发到数据库服务器。

故障排除:解析参数不匹配

使用 mysqli_connect 时出现错误“mysqli_connect()期望参数 6 为字符串,给定资源”表示函数参数不匹配。确保第五个参数(应该是隧道资源)是包含资源连接详细信息的字符串,而不是资源本身。

以上是如何在 PHP 中通过 SSH 隧道安全连接到 MySQL 数据库?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板