C# 桌面程序 链接 MySql数据库 写入信息

写到最前面(表明身份):自己也是个小白,程序简陋,功能简单,不喜勿喷! 

开发环境

开发Visual Studio 2022

框架 .NET Framework 4.8

服务器:阿里云(云服务器 ECS)

数据库:链接工具 Navicat Premium 12(网上有破解的,建议购买正版使用)

需要注意

1、数据库需要安装!

2、不同服务商的安全规则,以及使用的三方插件的规则(比如:我用的宝塔)

3、数据库语句

------------------------------------------以上写到前面------------------------------------------

打开端口
阿里安全组

3306 数据库连接默认端口,80  http的默认端口

宝塔面板

同时需要打开 3306端口

数据库
连接数据库

错误提示

解决方式

创建表

创建一个表(CODE),两个字段(ID自增,CODE默认值空)

------------------------------------------以上为连接数据库前的操作------------------------------------------

C# 连接数据库
1、安装数据库

2、数据库语句
"INSERT INTO 表 (字段) VALUES (要插入的值)";

链接数据库

string connStr = "server=IP;user=数据库用户名;database=数据库名;port=端口;password=密码";
 private void GetMachineCode()
 {

     using (MySqlConnection conn = new MySqlConnection(connStr))
     {
         try
         {
             // 打开连接
             conn.Open();
            
         }
         catch (Exception ex)
         {
             Console.WriteLine("Error: " + ex.Message);

         }
     }
 }

------------------------------------------以上为数据库的操作------------------------------------------

 代码整理
using MySql.Data.MySqlClient;
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Management;
using System.Security.Cryptography;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;

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

        private void button1_Click(object sender, EventArgs e)
        {
            GetMachineCode();
        }

        #region
        string connStr = "server=IP;user=数据库用户名;database=数据库名;port=端口;password=密码";
        /// <summary>
        //展示获取机器码
        /// </summary>
        private void GetMachineCode()
        {

            using (MySqlConnection conn = new MySqlConnection(connStr))
            {
                try
                {
                    // 打开连接
                    conn.Open();
                    // 2. 获取机器码
                    // 这里我们使用CPU的序列号作为示例,但在实际应用中可能需要其他信息
                    string machineCode = getRNum();
                    // 计算SHA256加密值
                    using (SHA256 sha256Hash = SHA256.Create())
                    {
                        // 计算输入文本的SHA256哈希值
                        byte[] bytes = sha256Hash.ComputeHash(Encoding.UTF8.GetBytes(machineCode));

                        // 将字节转换为十六进制字符串
                        StringBuilder builder = new StringBuilder();
                        for (int i = 0; i < bytes.Length; i++)
                        {
                            builder.Append(bytes[i].ToString("X2"));//转换大小写(“X”为大写值,“x”为小写值)
                        }
                        // 计算MD5哈希值
                        string md5Hash = ComputeMD5Hash(builder.ToString());
                        label2.Text = md5Hash;
                    }
                }
                catch (Exception ex)
                {
                    Console.WriteLine("Error: " + ex.Message);

                }
                // 3. 插入数据
                string md5 = label2.Text;
                string query = "INSERT INTO CODE (CODE) VALUES (@md5)";
                using (MySqlCommand cmd = new MySqlCommand(query, conn))
                {
                    cmd.Parameters.AddWithValue("@md5", md5);
                    cmd.ExecuteNonQuery();
                    conn.Close();
                }
            
                }
        }

        /// <summary>
        //MD5加密(SHA256值)
        /// </summary>
        private string ComputeMD5Hash(string input)
        {
            // 创建一个MD5CryptoServiceProvider对象
            using (MD5 md5Hash = MD5.Create())
            {
                // 计算输入字符串的MD5哈希值
                byte[] data = md5Hash.ComputeHash(Encoding.UTF8.GetBytes(input));

                // 创建一个StringBuilder对象来存储哈希值的字符串表示形式
                StringBuilder sBuilder = new StringBuilder();

                // 遍历哈希值的每个字节,并将其格式化为十六进制字符串
                for (int i = 0; i < data.Length; i++)
                {
                    sBuilder.Append(data[i].ToString("X2"));//转换大小写(“X”为大写值,“x”为小写值)
                }

                // 返回十六进制字符串
                return sBuilder.ToString();
            }
        }

        /// <summary>
        //获取CPU信息
        /// </summary>
        public static string GetCpuInfo()
        {
            string strCpu = null;
            ManagementClass myCpu = new ManagementClass("win32_Processor");
            ManagementObjectCollection myCpuConnection = myCpu.GetInstances();
            foreach (ManagementObject myObject in myCpuConnection)
            {
                strCpu = myObject.Properties["Processorid"].Value.ToString();
                break;
            }
            return strCpu;
        }

        /// <summary>
        //获取硬盘信息
        /// </summary>
        public static string GetDiskInfo()
        {
            ManagementClass mc = new ManagementClass("Win32_NetworkAdapterConfiguration");
            ManagementObject disk = new ManagementObject("win32_logicaldisk.deviceid=\"c:\"");
            disk.Get();
            return disk.GetPropertyValue("VolumeSerialNumber").ToString();
        }

        /// <summary>
        /// 获取网卡MAC地址
        /// </summary>
        public static string GetNetCardMACAddress()
        {
            ManagementObjectSearcher searcher = new ManagementObjectSearcher("SELECT * FROM Win32_NetworkAdapter WHERE ((MACAddress Is Not NULL) AND (Manufacturer <> 'Microsoft'))");
            string NetCardMACAddress = "";
            foreach (ManagementObject mo in searcher.Get())
            {
                NetCardMACAddress = mo["MACAddress"].ToString().Trim();
            }
            return NetCardMACAddress;

        }


        /// <summary>
        /// 生成24位机器码
        /// </summary>
        public static string getMNum()
        {
            string strNum = GetCpuInfo() + GetDiskInfo() + GetNetCardMACAddress();//获得24位Cpu+硬盘序列号+网卡地址
            string strMNum = strNum.Substring(0, 24);//从生成的字符串中取出前24个字符做为机器码
            return strMNum;
        }
        public int[] intCode = new int[127];//存储密钥
        public int[] intNumber = new int[25];//存机器码的Ascii值
        public char[] Charcode = new char[25];//存储机器码字
        public void setIntCode()//给数组赋值小于10的数
        {
            for (int i = 1; i < intCode.Length; i++)
            {
                intCode[i] = i % 9;
            }
        }
        public string getRNum()
        {
            setIntCode();//初始化127位数组
            string MNum = getMNum();//获取注册码
            for (int i = 1; i < Charcode.Length; i++)//把机器码存入数组中
            {
                Charcode[i] = Convert.ToChar(MNum.Substring(i - 1, 1));
            }
            for (int j = 1; j < intNumber.Length; j++)//把字符的ASCII值存入一个整数组中。
            {
                intNumber[j] = intCode[Convert.ToInt32(Charcode[j])] + Convert.ToInt32(Charcode[j]);
            }
            string strAsciiName = "";//用于存储注册码
            for (int j = 1; j < intNumber.Length; j++)
            {
                if (intNumber[j] >= 48 && intNumber[j] <= 57)//判断字符ASCII值是否0-9之间
                {
                    strAsciiName += Convert.ToChar(intNumber[j]).ToString();
                }
                else if (intNumber[j] >= 65 && intNumber[j] <= 90)//判断字符ASCII值是否A-Z之间
                {
                    strAsciiName += Convert.ToChar(intNumber[j]).ToString();
                }
                else if (intNumber[j] >= 97 && intNumber[j] <= 122)//判断字符ASCII值是否a-z之间
                {
                    strAsciiName += Convert.ToChar(intNumber[j]).ToString();
                }
                else//判断字符ASCII值不在以上范围内
                {
                    if (intNumber[j] > 122)//判断字符ASCII值是否大于z
                    {
                        strAsciiName += Convert.ToChar(intNumber[j] - 10).ToString();
                    }
                    else
                    {
                        strAsciiName += Convert.ToChar(intNumber[j] - 9).ToString();
                    }
                }
            }
            return strAsciiName;//返回注册码

        }




        #endregion

    }
}

点击获取机器码后,自动写入数据库,后续判断是否存在,增删改查等等,自己写了。

以上为全部代码,以上一篇机器码为底,继续添加了,连接数据库。

还是一样,代码不多,只是个案例,希望有用。

源码也会打包,上传。

点击富裕通道https://download.csdn.net/download/q234579464573499/89095807

  • 10
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在 C# 窗体程序中从 MySQL 数据库中下载文件,可以采用以下步骤: 1. 首先,需要在 MySQL 数据库中创建一个 BLOB 字段,并将文件存储在该字段中。 2. 在 C# 窗体程序中,需要使用 MySQL 数据库连接库和命令库来连接 MySQL 数据库,并执行 SQL 查询语句,以获取包含文件内容的 BLOB 字段。 3. 将 BLOB 数据转换为 byte[] 数组,并将其写入磁盘上的文件中。 下面是一个示例代码,演示如何从 MySQL 数据库中下载文件: ```c# using System; using System.Data; using System.IO; using System.Windows.Forms; using MySql.Data.MySqlClient; namespace DownloadFileFromMySQL { public partial class Form1 : Form { private MySqlConnection connection; private MySqlCommand command; public Form1() { InitializeComponent(); } private void button1_Click(object sender, EventArgs e) { // 连接 MySQL 数据库 connection = new MySqlConnection("server=localhost;database=test;uid=root;pwd=123456;"); connection.Open(); // 查询包含文件内容的 BLOB 字段 command = new MySqlCommand("SELECT file_content FROM files WHERE file_name=@name", connection); command.Parameters.AddWithValue("@name", "test.txt"); MySqlDataReader reader = command.ExecuteReader(); if (reader.Read()) { // 将 BLOB 数据转换为 byte[] 数组,并将其写入磁盘上的文件中 byte[] fileData = (byte[])reader["file_content"]; File.WriteAllBytes("test.txt", fileData); MessageBox.Show("Download completed!"); } else { MessageBox.Show("File not found!"); } reader.Close(); connection.Close(); } } } ``` 以上代码中,假设在 MySQL 数据库中已经创建了一个名为 `files` 的表,其中包含两个字段 `file_name` 和 `file_content`,`file_content` 字段为 BLOB 类型。下载文件时,根据文件名查询对应的 BLOB 数据,并将其写入磁盘上的文件中。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值