如何在windows应用程序中实现电子注册功能

上传人:xzh****18 文档编号:35420456 上传时间:2018-03-15 格式:DOCX 页数:10 大小:29.39KB
返回 下载 相关 举报
如何在windows应用程序中实现电子注册功能_第1页
第1页 / 共10页
如何在windows应用程序中实现电子注册功能_第2页
第2页 / 共10页
如何在windows应用程序中实现电子注册功能_第3页
第3页 / 共10页
如何在windows应用程序中实现电子注册功能_第4页
第4页 / 共10页
如何在windows应用程序中实现电子注册功能_第5页
第5页 / 共10页
点击查看更多>>
资源描述

《如何在windows应用程序中实现电子注册功能》由会员分享,可在线阅读,更多相关《如何在windows应用程序中实现电子注册功能(10页珍藏版)》请在金锄头文库上搜索。

1、如何在 Windows 应用程序中实现电子注册功能 目前,国内软件销售过程中采用了一种新的方式:开发者根据计算机中不 同 的硬件配置标志直接在应用程序中设置密钥,限制程序的使用次数或者限制某 些 先进功能的使用,然后将受限制的应用程序无偿提供给用户。用户在试用一段 时 间之后如果觉得很满意,就可以将安装程序提取的硬件配置解密密钥或已经采 集 机器配置情况的应用程序提供给开发者,并花少量费用购买自己机器中的电子 注 册密钥,从而能够充分利用应用程序的所有功能。 在应用程序中利用电子注册来限制应用程序的部分功能,这样既可以让用 户 先试用然后再决定是否购买应用程序,又保护了开发者的合法劳动成果,减

2、少 了 用户与开发者之间的不必要的中间环节。开发者直接得到用户购买软件的费用,真正地体现了开发者所创造的价值;用户在试用软件之后再决定是否购买,从 而 使得用户能够得到称心如意、物有所值的软件。因此,不通过中间环节这种销 售 方式降低了软件的成本,使开发者和用户双方都受益。同时,这种方式还可以 使 得开发者能够直接获得用户的反馈信息,促使开发者开发出功能更加完善的应 用 程序。 然而,要想在应用程序中实现电子注册功能决不是件容易的事情,尤其是 在 Windows 平台推出以后,要想实现一个跨平台的应用程序电子注册功能,则要 求 开发者应具有丰富的编程技巧和实际开发经验以及广阔的开发视野。笔者通

3、过 实 践探索,终于成功地实现了跨越 DOS、Windows 3.X 和 Windows 95 平台的应用 程序 电子注册功能。下面将阐述其实现原理及技巧。 一、注册密钥点的选择与生成 实现应用程序的电子注册功能,最关键的问题是采集硬件配置中的密钥点。在 DOS 系统下,可以通过硬盘端口 1F6H 和 1F7H 直接读取硬盘的序列号等作为 密钥 算法的数据,因为每块硬盘的型号、版本号和序列号均不同,只要用户提供上 述 内容,利用这种方法生成的注册密钥在每台计算机中均不同,从而实现电子注 册 的功能。著名的字表处理软件 CCED 5.18 中采用的就是类似的方法。虽然这种 方法 在绝大数场合下很

4、有效,甚至可以在 Windows 3.X 系统和 Windows 95 系统的兼 容模 式下通过,但在最高性能配置的 Windows 95 保护模式下却行不通,原因是 Windows 95 保护模式下不允许通过端口方式读取硬盘类型参数,所以利用这种方法无法 实 现跨平台的通用电子注册功能。 本人仔细分析计算机中 ROM 区的 F000H-FFFFH 内容后 ,发现该区域中记录 着很 多与硬件配置有关的信息(如 CMOS 配置信息、主板名称、型号和序列号、主机 标 志字节和生产日期等)。可以采集其中一处或几处作为注册密钥算法的原始数 据 (如机器 ROM 区中的 F000H:FFF5H-F000

5、H:FFFFH 中依次存放主机出厂日期和主 机标 志字节的内容),这些硬件特有的信息对于不同型号的计算机来说是不可能相 同 的。因此,完全可以将其作为注册密钥算法的原始数据,而且这些内容在 DOS、 Windows 3.X 和 Windows 95 下均相同。需要注意的是,如果在实际应用中真的 将该 采集点作为算法的原始数据,则不应该包括 F000:FFF0H 开始的前五个字节的内 容 ,原因是该地址已被用作机器热启动时的入口地址,在 DOS、Windows 3.X 和 Windows 95 系统中对热启动复合键 Ctrl+Alt+Del 的处理程序均不同,因此该 处的 内容在三者之中也都不相

6、同,读者应记住这一点。 利用上述方法取得注册密钥算法的原始数据后,开发者就可以确定自己的 加 密算法,这可以通过编程语言中丰富的位操作功能来实现。然后将注册加密算 法增加到应用程序中需要限制的部分,并可根据应用程序的实际需要和限制的功 能 任意设置多处,使盗版者很难解密,从而有效地保护开发者的成果。利用这一 方 法,即使机器中有多个应用程序使用相同的硬件配置信息采集点,也不可能发 生 任意加密冲突问题;即便是使用了相同的算法原始数据,由于算法不同,注册 密 钥也不会完全相同;即使解密者知道加密算法的原始数据,由于无法知道加密 算 法,再加上加密算法贯穿于整个应用程序,所以很难解密。因此,上述方

7、法可 以 有效地实现跨越 DOS、Windows 3.X 和 Windows 95 平台的电子注册功能。此外, 由 于 ROM 区关键点的内容不可能发生变化,所以即使将来推出新型的操作系统平 台 ,这种方法仍然会很有效。 二、利用解密密钥建立联系 应用程序的加密部分完成之后,就需要建立相应的解密密钥。所谓解密密 钥 ,就是将加密算法的原始数据经过加密之后,直接显示给用户并写入应用程序 的 相应位置。这样,用户既可以通过电话或计算机网络给开发者提供注册功能的 算 法原始数据,也可以将安装后的应用程序寄给开发者。加密密钥既可以是 ROM 区 域内的原始数据(最好不要原样提供),也可以是由原始数据经

8、过一定换算后 形 成的新的数据。因此,开发者提供的应用程序中的加密算法部分应包括两部分:将机器 ROM 区域内的数据经过解密密钥算法后形成解密密钥,再将解密密钥数 据 经注册算法后形成注册密钥。 应用程序中注册密钥的算法、注册密钥的长度、显示或提供给开发者的方 式 可自己确定,但解密密钥的长度和算法应与注册密钥完全相同。解密密钥也没 有 必要做得那么复杂,只需进行简单处理后就可以实现,例如本文程序中实现的 方 法是将 ROM 中采集的数据简单地减去 0x2020。 三、电子注册密钥生成程序 开发者得到用户提供的解密密钥原始数据后,需要利用专用的密钥生成程 序 将其转换成注册密钥,并将注册密钥交

9、给用户。注册密钥的算法与应用程序中 判 断注册密钥的加密算法程序应该完全相同。该程序一般应具有以下三种取得注 册 密钥算法原始数据的方式,以方便进行密钥的处理。该程序的名称为 READKEY.EXE ,其功能如下: (1)当 READKEY 不带参数时,则直接从当前机器中取得注册密钥; (2)当 READKEY 带参数时,则从键盘输入解密密钥来获取注册密钥; (3)当 READKEY 带 EXE 文件名参数时,则从相应应用程序的特定位置取得 解密 密钥,并生成注册密钥。 用户得到注册密钥后,重新安装一次应用程序或在需要输入注册密钥处直 接 输入密钥,则应用程序会自动将这个注册密钥存放到文件的特

10、定位置处,当应 用 程序被他人拷贝到其它机器中之后,由于注册密钥随机器的不同而不同,所以 应 用程序的功能或使用次数仍然受限,要想在其它机器中使用该应用程序,则必 须 重新注册。 应用程序中解密密钥和注册密钥的位置,可先用特殊字符来标识,然后用 DEBUG 等程序直接查找其位置,再修改其它程序中读取或写入数据的地址值。 至 于解密密钥显示和注册密钥的输入方式,可由开发者确定是用安装程序的方法 还 是在应用程序中直接处理的方法。 /*电子注册功能密钥读取程序清单 READKEY.C*/ #include #include #include #include #include #include #

11、include #include #include #include #include void readser(void); void readser1(void); unsigned char Buff18; unsigned int keyrom9; unsigned int sum,sumi,sumj; unsigned int far *pt= (unsigned int far *)0xf000fff6L; unsigned int i=0,j=0,m; unsigned char p; unsigned int nn,nn1,nn2; unsigned char rbuff100

12、,cc,cc1,cc2; int fp; void main(int argc,char *argv) if(argc3)|(argc=2) scanf(“%s“,rbuff); /手工输入加密密钥 printf(“sss:%s,%un“,rbuff,strlen(rbuff); j=strlen(rbuff); if(j!=20) exit(1); for(i=0;i=a) if(strstr(argv1,“.EXE“)=NULL) printf(“USAGE:READKEY 路径及文件名.n“); exit(1); if(fp=open(argv1,O_RDWR|O_BINARY)=-1)

13、 printf(“File %s open error!“,argv1); exit(1); lseek(fp,0xf040L,SEEK_SET);/ROM 10 个数据地址+200H read(fp,keyrom,0xaL); /读取数据 readser1(); /读文件中的注册密钥 else readser(); /读机器中的注册密钥 void readser(void) sum=0x2020; for(sumj=0;sumj4;sumj+)/形成 16 位密钥 for(sumi=0;sumi5;sumi+) sum-=(*(pt+sumi)-0x2020);/形成解密密钥 sum=0x0

14、404 sprintf(Buff+4*sumj,“%04x“,sum); printf(Buff); void readser1(void) sum=0x2020; for(sumj=0;sumj4;sumj+)/形成 16 位密钥 for(sumi=0;sumi5;sumi+) sum-=keyromsumi; /形成解密密钥 sum=0x0404 sprintf(Buff+4*sumj,“%04x“,sum); printf(Buff); 四、应用程序中密钥的读取及限制 当应用程序进行电子注册之后,安装程序会将注册密钥写入到应用程序中。 在应用程序中,判断是否进行注册的方法就是重新生成注册

15、密钥并进行判断处 理。注册密钥的读取函数如下: void ImeCmpkey(void) /Windows 下注册密钥的读取函数 static unsigned int sum,sumi,sumj; static BOOL flag; static unsigned int far *pt; static UINT Sel1,Sel2; static WORD Seg,Off,Start; static DWORD Bas,Lim; flag=TRUE; sum=0x2020; _asm mov Sel1,ds; /将 DS 作为模板 Sel2=AllocSelector(Sel1); /分配

16、一个新选择符 if(Sel2=NULL) flag=FALSE; pt=(unsigned int far*)0xf000fff0L; else Seg=0xffff; /绝对地址段址 Off=0x10; /绝对地址偏移 Start=0x0; Bas=(unsigned long)Seg)4|Start; Lim=(unsigned long)Off-1; SetSelectorBase(Sel2,Bas); SetSelectorLimit(Sel2,Lim); pt=(unsigned int far*)(unsigned long)Sel2)16)|Start); for(sumj=0;sumj4;sumj+) /形成 16 位密钥 for(sumi=0;sumi5;sumi+) sum-=(*(pt+3+sumi)-0x2020);/形成解密密钥 su

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > IT计算机/网络 > 多媒体应用

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号