winform 加密连接数据库

在app.config中有配置代码如下:

<configuration>
  <appSettings>
    <add key="ConStringEncrypt" value="false" />
    <add key="ConnectionString" value="Server=localhost;Database=testmysql;User=root;Password=xiaowei;Port=3306;Charset=utf8" />
  </appSettings>

</configuration>

在程序开始运行处加密数据库连接信息,防止别人盗用数据库密码信息

 static class Program
    {
        /// <summary>
        /// 应用程序的主入口点。
        /// </summary>
        [STAThread]
        static void Main()
        {
            // 链接字符串加密
            string ConStringEncrypt = ConfigurationManager.AppSettings["ConStringEncrypt"];
            string _connectionString = ConfigurationManager.AppSettings["ConnectionString"]; 
            if (ConStringEncrypt == "false")
            {
                _connectionString = DESEncrypt.Encrypt(_connectionString);
                // 写入到config文件中
              SetValue(Application.ExecutablePath + ".config",  "ConStringEncrypt", "true");
                SetValue(Application.ExecutablePath + ".config",  "ConnectionString", _connectionString);                 
            }


            Application.EnableVisualStyles();
            Application.SetCompatibleTextRenderingDefault(false);
            Application.Run(new FormMain());
        }

}

 public static void SetValue(string configPath, string AppKey, string AppValue)
        {
            XmlDocument xDoc = new XmlDocument();
            //获取可执行文件的路径和名称
            xDoc.Load(configPath);
            XmlNode xNode;
            XmlElement xElem1;
            XmlElement xElem2;
            xNode = xDoc.SelectSingleNode("//appSettings");
            xElem1 = (XmlElement)xNode.SelectSingleNode("//add[@key='" + AppKey + "']");
            if (xElem1 != null) xElem1.SetAttribute("value", AppValue);
            else
            {
                xElem2 = xDoc.CreateElement("add");
                xElem2.SetAttribute("key", AppKey);
                xElem2.SetAttribute("value", AppValue);
                xNode.AppendChild(xElem2);
            }
            xDoc.Save(configPath);
        }
    }

一下是加密解密程序:

public class DESEncrypt
{
public DESEncrypt()
{
}


#region ========加密======== 
 
        /// <summary>
        /// 加密
        /// </summary>
        /// <param name="Text"></param>
        /// <returns></returns>
public static string Encrypt(string Text) 
{
            return Encrypt(Text, "Otitan");
}
/// <summary> 
/// 加密数据 
/// </summary> 
/// <param name="Text"></param> 
/// <param name="sKey"></param> 
/// <returns></returns> 
public static string Encrypt(string Text,string sKey) 

DESCryptoServiceProvider des = new DESCryptoServiceProvider(); 
byte[] inputByteArray; 
inputByteArray=Encoding.Default.GetBytes(Text); 
des.Key = ASCIIEncoding.ASCII.GetBytes(System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(sKey, "md5").Substring(0, 8)); 
des.IV = ASCIIEncoding.ASCII.GetBytes(System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(sKey, "md5").Substring(0, 8)); 
System.IO.MemoryStream ms=new System.IO.MemoryStream(); 
CryptoStream cs=new CryptoStream(ms,des.CreateEncryptor(),CryptoStreamMode.Write); 
cs.Write(inputByteArray,0,inputByteArray.Length); 
cs.FlushFinalBlock(); 
StringBuilder ret=new StringBuilder(); 
foreach( byte b in ms.ToArray()) 

ret.AppendFormat("{0:X2}",b); 

return ret.ToString(); 



#endregion

#region ========解密======== 
   
 
        /// <summary>
        /// 解密
        /// </summary>
        /// <param name="Text"></param>
        /// <returns></returns>
public static string Decrypt(string Text) 
{
            return Decrypt(Text, "Otitan");
}
/// <summary> 
/// 解密数据 
/// </summary> 
/// <param name="Text"></param> 
/// <param name="sKey"></param> 
/// <returns></returns> 
public static string Decrypt(string Text,string sKey) 

DESCryptoServiceProvider des = new DESCryptoServiceProvider(); 
int len; 
len=Text.Length/2; 
byte[] inputByteArray = new byte[len]; 
int x,i; 
for(x=0;x<len;x++) 

i = Convert.ToInt32(Text.Substring(x * 2, 2), 16); 
inputByteArray[x]=(byte)i; 

des.Key = ASCIIEncoding.ASCII.GetBytes(System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(sKey, "md5").Substring(0, 8)); 
des.IV = ASCIIEncoding.ASCII.GetBytes(System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(sKey, "md5").Substring(0, 8)); 
System.IO.MemoryStream ms=new System.IO.MemoryStream(); 
CryptoStream cs=new CryptoStream(ms,des.CreateDecryptor(),CryptoStreamMode.Write); 
cs.Write(inputByteArray,0,inputByteArray.Length); 
cs.FlushFinalBlock(); 
return Encoding.Default.GetString(ms.ToArray()); 

 
#endregion 




}

具体实现过程如下: 1. 确定数据传输方式 这里我们使用 WebSocket 进行实时数据传输。使用 WebSocket 的好处是可以保持长连接,实现实时数据传输。 2. Winform 中连接 MySQL 数据库Winform 中连接 MySQL 数据库,使用 MySQL.Data 库进行连接。添加代码如下: ``` using MySql.Data.MySqlClient; public void Connect() { string connStr = "server=localhost;user=root;database=test;port=3306;password=123456;"; MySqlConnection conn = new MySqlConnection(connStr); try { conn.Open(); } catch (Exception ex) { Console.WriteLine(ex.ToString()); } conn.Close(); } ``` 其中,`server`、`user`、`database`、`port`、`password` 是连接 MySQL 数据库的参数。 3. Web 客服系统中连接 MySQL 数据库 在 Web 客服系统中连接 MySQL 数据库,使用 JDBC 进行连接。添加代码如下: ``` String url = "jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=UTF-8&zeroDateTimeBehavior=convertToNull&allowMultiQueries=true&autoReconnect=true&failOverReadOnly=false&maxReconnects=10"; String user = "root"; String password = "123456"; Connection conn = DriverManager.getConnection(url, user, password); ``` 其中,`url`、`user`、`password` 是连接 MySQL 数据库的参数。 4. Winform 窗体中添加 WebBrowser 控件 在 Winform 窗体中添加 WebBrowser 控件,用于显示 Web 客服系统页面。添加代码如下: ``` private void Form1_Load(object sender, EventArgs e) { webBrowser1.Navigate("http://localhost:8080/chat"); } ``` 其中,`http://localhost:8080/chat` 是 Web 客服系统的地址。 5. Web 客服系统中添加接口 在 Web 客服系统中添加接口,用于接收 Winform 窗体传来的数据,并进行数据处理和存储。添加代码如下: ``` // 接收消息 @OnWebSocketMessage public void onMessage(Session session, String message) { // 处理消息 // 存储消息 Connection conn = DriverManager.getConnection(url, user, password); PreparedStatement pstmt = conn.prepareStatement("INSERT INTO message(content) VALUES(?)"); pstmt.setString(1, message); pstmt.executeUpdate(); pstmt.close(); conn.close(); } ``` 6. Winform 窗体中使用 WebSocket 连接 Web 客服系统 在 Winform 窗体中使用 C# 的 WebSocket 连接 Web 客服系统,实现数据传输。添加代码如下: ``` var uri = new Uri("ws://localhost:8080/chat"); var ws = new WebSocket(uri); ws.OnMessage += (sender, e) => { // 处理消息 }; ws.Connect(); ``` 7. 数据的实时同步 使用 WebSocket 进行实时数据传输,使得 Winform 窗体和 Web 客服系统之间的数据保持同步。添加代码如下: ``` // Winform 窗体发送消息 ws.Send("hello"); // Web 客服系统发送消息 session.getRemote().sendString("world"); ``` 8. 数据的安全性 在数据传输过程中进行加密和身份验证,以确保数据的安全性。这里我们可以使用 SSL/TLS 进行数据加密,使用 JWT 进行身份验证。 具体实现代码如下: ``` // Winform 窗体连接 Web 客服系统 var uri = new Uri("wss://localhost:8080/chat"); var ws = new WebSocket(uri); ws.OnMessage += (sender, e) => { // 处理消息 }; ws.SslConfiguration.EnabledSslProtocols = SslProtocols.Tls12; ws.SetCredentials("username", "password", false); ws.SetCookie(new WebSocketSharp.Net.Cookie("jwt", "token")); ws.Connect(); ``` 以上就是 Winform+MySQL数据库 和 Web 客服系统对接并实现数据实时同步和传输的具体实现过程和代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值