C#通過SSH連接MySql


  出於安全考慮,有的時候數據庫服務器只能通過SSH訪問,比如MySql服務裝在了服務器A上,並且A機器只允許B機器才能訪問,而部署環境可能在C機器上,這時候就要C服務器通過B服務器連接A服務器,這時候就需要用到SSH方式連接,需要SSH.NET類庫:

下載地址:https://github.com/sshnet/SSH.NET

 

  代碼如下:

  

using MySql.Data.MySqlClient;
using Renci.SshNet;
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;

namespace SSHMySql
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
            SSHConnectMySql();
        }

        public void SSHConnectMySql()
        {
            string SSHHost = "*.*.*.*";        // SSH地址
            int SSHPort = 22;              // SSH端口
            string SSHUser = "user";           // SSH用戶名
            string SSHPassword = "pwd";           // SSH密碼

            string sqlIPA = "127.0.0.1";// 映射地址  實際上也可以寫其它的   Linux上的MySql的my.cnf bind-address 可以設成0.0.0.0 或者不設置
            string sqlHost = "192.168.1.20"; // mysql安裝的機器IP 也可以是內網IP 比如:192.168.1.20
            uint sqlport = 3306;        // 數據庫端口及映射端口
            string sqlConn = "Database=mysql;Data Source=" + sqlIPA + ";Port=" + sqlport + ";User Id=user;Password=pwd;CharSet=utf8";
            string sqlSELECT = "select * from user";

            PasswordConnectionInfo connectionInfo = new PasswordConnectionInfo(SSHHost, SSHPort, SSHUser, SSHPassword);
            connectionInfo.Timeout = TimeSpan.FromSeconds(30);
            using (var client = new SshClient(connectionInfo))
            {
                try
                {
                    client.Connect();
                    if (!client.IsConnected)
                    {
                        MessageBox.Show("SSH connect failed");
                    }

                    var portFwdL = new ForwardedPortLocal(sqlIPA, sqlport, sqlHost, sqlport); //映射到本地端口
                    client.AddForwardedPort(portFwdL);
                    portFwdL.Start();
                    if (!client.IsConnected)
                    {
                        MessageBox.Show("port forwarding failed");
                    }

                    MySqlConnection conn = new MySqlConnection(sqlConn);
                    MySqlDataAdapter myDataAdapter = new MySqlDataAdapter();
                    myDataAdapter.SelectCommand = new MySqlCommand(sqlSELECT, conn);

                    try
                    {
                        conn.Open();
                        DataSet ds = new DataSet();
                        myDataAdapter.Fill(ds);
                        dataGridView1.DataSource = ds.Tables[0];
                    }
                    catch (Exception ee)
                    {
                        MessageBox.Show(ee.Message);
                    }
                    finally
                    {
                        conn.Close();
                    }

                    client.Disconnect();
                }
                catch (Exception ex)
                {
                    MessageBox.Show(ex.Message);
                }
            }
        }
    }
}

注:如果出現錯誤可以把本地(開發機器)上的MySql服務停止掉。

需要的dll:SSHDLL.rar


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM