日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > C# >内容正文

C#

C#通过SSH连接MySql

發布時間:2023/11/29 C# 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 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.20uint 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

轉載于:https://www.cnblogs.com/sunyj/p/6070206.html

總結

以上是生活随笔為你收集整理的C#通过SSH连接MySql的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。