给既有exe程序添加一机一码验证

news/2024/12/22 16:08:41/

原文地址:李浩的博客 lihaohello.top


本科期间开发过一款混凝土基本构件设计程序,该程序是一个独立的exe可执行文件,采用VC++静态链接MFC库编制而成。近期,需要为该程序添加用户注册验证的功能,从而避免任何用户获取该程序就能无限制使用的问题。

刚开始,打算在网络上找可直接为单个exe文件添加“一机一码”注册功能的平台软件,但该类软件基本都是付费软件,且生成的加壳程序很容易被杀毒软件误差。好在“一机一码”机制并不复杂,最终决定使用C#编程的方式手动实现该功能。

整体思路

  1. 新建C#控制台程序,将exe嵌入C#的资源文件
  2. 控制台程序启动后,先进行“一机一码”校验:
    • 如果已注册,直接进入第3步
    • 如果未注册,则弹出注册窗口,提示用户输入注册码:注册成功进入第3步;失败继续提示输入注册码或退出
  3. 通过代码从资源文件中释放exe,并启动新进程,控制台进程等待新进程执行完毕再退出

主要问题

“一机一码”的验证策略

  • 先获取硬件(CPU、硬盘等)的序列号,通过序列号组合成机器码
  • 通过某种加密算法从机器码计算得到注册码,并把注册码写入特定的文件或注册表
  • 每次打开加壳程序时,都先获取机器码计算注册码,将计算得到的注册码与保存在本地的注册码进行比较,如果一致就说明注册成功,反之失败

以下是获取CPU和硬盘序列号的函数:

public static string GetCPUId() {try {ManagementObjectCollection collection1 = new ManagementClass("Win32_Processor").GetInstances();string strCpuID = null;foreach (ManagementObject obj1 in collection1) {strCpuID = obj1.Properties["ProcessorId"].Value.ToString();break;}return strCpuID;} catch {return "strCpuID";}
}public static string GetDiskId() {try {ManagementObjectSearcher searcher = new ManagementObjectSearcher("SELECT * FROM Win32_PhysicalMedia");String strHardDiskID = null;foreach (ManagementObject mo in searcher.Get()) {strHardDiskID = mo["SerialNumber"].ToString().Trim();break;}return strHardDiskID;} catch {return "strHardDiskID";}
}

释放资源获得原始文件

  • 这里需要指定释放文件的保存路径,可以选择当前用户的临时文件夹
  • 可以设置释放文件的状态为隐藏,为用户拷贝该文件制造额外障碍
byte[] fileBytes = Resource1.program;
string fileName = System.IO.Path.GetTempPath();
if (fileName.EndsWith("\\"))fileName = fileName + "program.exe";
elsefileName = fileName + "\\program.exe";
using (BinaryWriter bw = new BinaryWriter(new System.IO.FileStream(fileName, System.IO.FileMode.Create))) {bw.Write(fileBytes);bw.Flush();bw.Dispose();
}
File.SetAttributes(fileName, FileAttributes.Hidden);

执行释放程序并等待其结束

System.Diagnostics.Process myPro = System.Diagnostics.Process.Start(fileName);
myPro.WaitForExit();

注意事项

  1. 释放exe文件后,该文件必定存在于本机某个路径,高级用户可以找到该路径并拷贝exe文件,从而轻松破解。这是本方法的硬伤,只能通过选择隐蔽路径、设置文件隐藏等方法加大定位该文件的难度。
  2. 由于采用C#语言进行加壳,很容易反编译得到加壳逻辑,这样从机器码到注册码的算法逻辑就非常容易被破解者发现,从而自己计算实现注册。解决该方法的办法是:使用C+ +编写机器码到注册码的算法逻辑,然后封装给C#程序调用;或者使用C+ +来进行加壳;或者更彻底一些,将注册码计算过程部署到服务器,通过网络来进行验证。
  3. 软件开发者端需要额外的注册码计算程序,从而实现软件分发控制。

http://www.ppmy.cn/news/1510647.html

相关文章

谈对象系列:C++类和对象

文章目录 一、类的定义1.1类定义的格式类的两种定义方法结构体: 1.2访问限定符1.3类域 二、实例化2.1变量的声明和定义2.2类的大小计算空类的大小(面试): 三、this指针小考题 一、类的定义 1.1类定义的格式 使用class关键字&…

【stm32项目】多功能智能家居室内灯光控制系统设计与实现(完整工程资料源码)

多功能智能家居室内灯光控制系统设计与实现 目录: 目录: 前言: 一、项目背景与目标 二、国内外研究现状: 2.1 国内研究现状: 2.2 国外研究现状: 2.3 发展趋势 三、硬件电路设计 3.1 总体概述 3.2 硬件连接总…

大公报发表欧科云链署名文章:发行港元稳定币,建Web3.0新生态

欧科云链研究院资深研究员蒋照生近日与香港科技大学副校长兼香港Web3.0协会首席科学顾问汪扬、零壹智库创始人兼CEO柏亮,在大公报发布联合署名文章 ——《Web3.0洞察 / 发行港元稳定币,建Web3.0新生态》,引发市场广泛讨论。 文章就香港稳定币…

视频美颜SDK与直播美颜工具:实现实时美颜的关键技术详解

本文将详细解析视频美颜SDK与直播美颜工具的核心技术,探讨其如何实现实时美颜效果。 一、视频美颜SDK的核心技术 1.人脸识别与面部特征提取 通过这些特征点,SDK可以对面部进行精确定位,为后续的美颜处理提供基础。 2.实时图像处理 这包括…

可乐机的设计验证

前言 状态机(State Machine)是一种数学模型,用于表示具有有限状态集合的系统。它通过定义状态、转移规则和事件,描述系统在不同条件下的行为。状态机的核心概念包括状态、事件、转移和动作。状态是系统的具体条件或配置&#xff0…

Python常用的模块

一、logging模块 一)日志级别 critical50 error40 waring30 info20 debug10 notset0 二)默认的日志级别是waring(30),默认的输出目标是终端 logging输出的目标有两种:1、终端;2、文件 高于warn…

Java面试题——第四篇(多线程)

1. sleep(0)的意义 他的意义在于 调用Thread.sleep(0)的当前线程确实的被冻结了一下,让其他线程有机会优先执行。相当于一个让位动作。 在线程没退出之前,线程有三个状态:就绪态、运行态、等待态。sleep(n) 之所以在n秒内不会参与CPU竞争&…

【代码随想录算法训练营第42期 第六天 | LeetCode242.有效的字母异位词、349. 两个数组的交集、202. 快乐数、1. 两数之和】

代码随想录算法训练营第42期 第六天 | LeetCode242.有效的字母异位词、349. 两个数组的交集、202. 快乐数、1. 两数之和 一、242.有效的字母异位词 解题代码C: bool isAnagram(char* s, char* t) {int len1 strlen(s);int len2 strlen(t);int al[26] {0};int b…