我想通过SSH通道连接到服务器上的mysql数据库。
我已下载此SSH.Net库。
这是我尝试过的,我认为在建立安全连接后它会起作用。
我的SSH连接已建立,但未执行与数据库的正常连接。
请检查我的代码:
using (var client = new SshClient("cpanel****", "******", "******"))
{
client.Connect();
con = new MySqlConnection(GetConnectionString());
con.Open();
cmd = new MySqlCommand(String.Format("insert into {0} values (null, ?Parname , ?Parname2, ?Parname3, ?Parname4, ?Parname5, ?Parname6, ?Parname7);", ConfigSettings.ReadSetting("main")), con);
cmd.Parameters.Add("?Parname", MySqlDbType.Double).Value = Math.Round(deciLat, 5);
// ... more parameters
cmd.ExecuteNonQuery();
client.Disconnect();
}
答案 0 :(得分:1)
这是一个合理的教程http://georgelantz.com/2007/09/10/access-mysql-through-ssh-tunnel-in-a-windows-net-application/。
基本思想是建立与隧道的SSH连接(也称为端口转发),然后将MySQL连接指向localhost。
SSH隧道将连接重定向到localhost:XX到ssh服务器端口:YY。所以你的端口YY将是mysql连接端口,在你的连接字符串中你将使用localhost:XX。
您正在使用的SSH库似乎也支持端口转发,因此您也可以将其工作。