大家好,欢迎来到IT知识分享网。
前言
本文将使用一个NuGet公开的组件技术来实现机器码注册码功能开发,提供了一些简单的API,来方便的实现。
在Visual Studio 中的NuGet管理器中可以下载安装,也可以直接在NuGet控制台输入下面的指令安装:
Install-Package HslCommunication
NuGet安装教程 C# 注册机功能开发,机器码设计
联系作者及加群方式(激活码在群里发放):http://www.hslcommunication.cn/Cooperation
Summary
在我开发完成一个软件后,尤其是要发放给别人使用的软件时,为了防止软件被恶意使用,有时候会采用注册机的机制来实现,比如我们会获取一串唯一的机器码,然后进行加密运算,程序在激活前就检测注册码是否正确,正确就启动程序,然后就启动失败,为了防止激活码被激活成功教程,通常都需要对程序加一层壳,也即是混淆,这样就能防止99%的开发者来激活成功教程注册码,要是真有大神愿意激活成功教程你的程序,只能证明你的程序很值钱了,即使大神激活成功教程,也免不了查出来要承担相应的法律责任。
Reference
CRC组件所有的功能类都在 HslCommunication.BasicFramework 命名空间,所以再使用之前先添加
using HslCommunication.BasicFramework
How to Use
情景一:程序启动验证注册码,如果注册码存在且正确,窗口继续运行,否则弹出输入注册码窗口,除非输入了正确的注册码,否则窗体退出
那么我们就需要在Form的Load方法中进行验证操作,先在Form下实例化授权类,然后需要提供一个你自己的从机器码到注册码的生成规则,实质上就是一个加密方法,你也可以参照下面的例子:
private HslCommunication.BasicFramework.SoftAuthorize softAuthorize = null; private void FormRegisterTest_Load(object sender, EventArgs e) { softAuthorize = new HslCommunication.BasicFramework.SoftAuthorize(); softAuthorize.FileSavePath = Application.StartupPath + @"\Authorize.txt"; // 设置存储激活码的文件,该存储是加密的 softAuthorize.LoadByFile(); // 检测激活码是否正确,没有文件,或激活码错误都算作激活失败 if (!softAuthorize.IsAuthorizeSuccess(AuthorizeEncrypted)) { // 显示注册窗口 using (HslCommunication.BasicFramework.FormAuthorize form = new HslCommunication.BasicFramework.FormAuthorize( softAuthorize, "请联系XXX获取激活码", AuthorizeEncrypted)) { if (form.ShowDialog() != DialogResult.OK) { // 授权失败,退出 Close(); } } } textBox1.Text = softAuthorize.GetMachineCodeString(); // 显示出机器码,情景二用 } /// <summary> /// 一个自定义的加密方法,传入一个原始数据,返回一个加密结果 /// </summary> /// <param name="origin"></param> /// <returns></returns> private string AuthorizeEncrypted(string origin) { // 此处使用了组件支持的DES对称加密技术 return HslCommunication.BasicFramework.SoftSecurity.MD5Encrypt(origin, "12345678"); }
在没有激活过的情况下,运行窗体就会显示注册窗口。
那么现在我们已经有机器码了,那么注册码怎么来呢?还记得上面的代码有个方法呢?就是AuthorizeEncrypted方法,只要吧这串机器码当作参数传入就可以获取到注册码,就可以填进去激活软件了。如果你填了错误的激活码,或是关闭了注册窗口,这个窗口就会退出。
在此处我的机器码如上面所示,执行这个方法后的注册码为:B384A9552ACFABF3CF839FB8A7CEAB123A264457BA0C176AE13F412CDD76C338,如果你的窗口为主窗口,那么授权功能已经写完了,假设你把软件分发出去了,拷贝给别人了,别人运行后就会弹出输入注册码,你就叫他把机器码发给你,你在写个窗口计算出注册码发给对方,对方就可以运行软件了。
情景二:不提供手动申请注册码,直接在软件里写死。每次分发软件都需要对方先提供机器码(你可以做个超级简单的exe,就只有显示机器码的功能),编译号软件再进行分发,这种更难激活成功教程。
但是也牺牲了一定的灵活度,在窗口载入中的代码如下:
private HslCommunication.BasicFramework.SoftAuthorize softAuthorize = null; private void FormRegisterTest_Load(object sender, EventArgs e) { softAuthorize = new HslCommunication.BasicFramework.SoftAuthorize(); //softAuthorize.FileSavePath = Application.StartupPath + @"\Authorize.txt"; // 设置存储激活码的文件,该存储是加密的 //softAuthorize.LoadByFile(); // 检测激活码是否正确,没有文件,或激活码错误都算作激活失败 //if (!softAuthorize.IsAuthorizeSuccess(AuthorizeEncrypted)) //{ // // 显示注册窗口 // using (HslCommunication.BasicFramework.FormAuthorize form = // new HslCommunication.BasicFramework.FormAuthorize( // softAuthorize, // "请联系XXX获取激活码", // AuthorizeEncrypted)) // { // if (form.ShowDialog() != DialogResult.OK) // { // // 授权失败,退出 // Close(); // } // } //} // 此处示例程序的机器码为:2E4C8EB0EBB8C4551C49AC277 // 直接进行判断,允不允许运行 if (!softAuthorize.CheckAuthorize("B384A9552ACFABF3CF839FB8A7CEAB123A264457BA0C176AE13F412CDD76C338", AuthorizeEncrypted)) { // 检测授权失败 Close(); } textBox1.Text = softAuthorize.GetMachineCodeString(); } /// <summary> /// 一个自定义的加密方法,传入一个原始数据,返回一个加密结果 /// </summary> /// <param name="origin"></param> /// <returns></returns> private string AuthorizeEncrypted(string origin) { // 此处使用了组件支持的DES对称加密技术 return HslCommunication.BasicFramework.SoftSecurity.MD5Encrypt(origin, "12345678"); }
目前的激活方式是基于本地的单机激活,如果需要采用联网激活的方式,那么也是非常容易实现的,在程序启动的时候,把机器码通过网络发送给服务器,根据服务器返回的值来判断有没有启动程序的权利。
在C#下方便的网络交互,请参考如下的文章:
C# 注册机功能开发,机器码设计
免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://yundeesoft.com/33396.html