写到最前面(表明身份):自己也是个小白,程序简陋,功能简单,不喜勿喷!
开发环境
开发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