繁体中文
设为首页
加入收藏
当前位置:编程开发首页 >> VB语言 >> 用Visual Basic为软件增加注册功能

用Visual Basic为软件增加注册功能
2006-07-02 10:34:23  作者:  来源:  浏览次数:0  网友评论0  文字大小:【】【】【】 评分等级:0

  在尊重软件著作权的时代,电子注册版软件的应用也越来越广。它的出现使用户对程序中未受限制的功能有了一定了解,起到了推广和传播作用,同时也很好地保护了制作人的切身利益。那么,我们如何制作一个电子注册版软件呢?

   经过摸索,笔者利用VB也简单地制作了一个电子注册版软件。



  设计原理

 

   利用API中的“GetVolumeInformation”函数提取使用者机器的硬盘序列号为特征码,注册时提交此码,经过软件著作权人加以运算,给出注册码,最后软件使用人输入注册码完成整个注册过程(为使说明简单,本例中以特征码减101做为注册码)。

   新建一模块文件

   新建一模块文件,并将如下声明的语句和常量添加到Module1.Bas模块中:

Declare Function GetVolumeInformation Lib "kernel32" Alias "GetVolumeInformationA"
(ByVal lpRootPathName As String, ByVal lpVolumeNameBuffer As String, ByVal
nVolumeNameSize As Long, lpVolumeSerialNumber As Long, lpMaximumComponentLength As
Long, lpFileSystemFlags As Long, ByVal lpFileSystemNameBuffer As String, ByVal
nFileSystemNameSize As Long) As Long

Global GetVal As Long

   编程时需注意的是要将声明语句写在同一行中。



  窗体设置

 

   在Form1上添加2个文本框,Name属性分别设置为Text1、Text2;再添加1个按钮,Name属性设置为Command1。

   添加代码

   将如下程序代码添加到Form1的Form1_Load事件中:

Private Sub Form_Load()

  Dim TempStr1 As String * 256
  Dim TempStr2 As String * 256
  Dim TempLon1 As Long
  Dim TempLon2 As Long

  ………

‘读取是否注册的信息,如何控制这里不再说明

  ………

  Call GetVolumeInformation("C:\", TempStr1, 256, GetVal, TempLon1, TempLon2, TempStr2, 256)
  Text1.Text = GetVal ‘提取本机C盘的序列号至文本框一
End Sub


    将如下程序代码添加到Command1的Command1_Click事件中:

 
Private Sub Command1_Click()

  If Text2 〈〉 CStr(GetVal) Then
   MsgBox "注册码不正确,请认真检查输入是否正确。"
  Else
   MsgBox "你已经成功注册,请重新启动本软件。"
   ………
  (将正确注册的信息写入,使软件功能以后不受限制。具体方法依个人爱好进行设置。)
   ………
  End If
End Sub

   至此,我们可以运行一下程序。你会发现我们已经简单地实现了利用硬盘序列号制作电子注册版软件的功能。


本文引用地址:http://www.linuxdiyf.com/1/article/2006/0702/article_685.html

责任编辑:linux

发表评论】 【加入收藏】 【告诉好友】 【打印本页】 【关闭窗口】 【返回顶部
相关评论 0条评论  发表/查看更多评论 
发表评论  【返回顶部】【关闭窗口】 
评分: 1 2 3 4 5

    
  • 请遵守《互联网电子公告服务管理规定》及中华人民共和国其他各项有关法律法规。
  • 严禁发表危害国家安全、损害国家利益、破坏民族团结、破坏国家宗教政策、破坏社会稳定、侮辱、诽谤、教唆、淫秽等内容的评论 。
  • 用户需对自己在使用本站服务过程中的行为承担法律责任(直接或间接导致的)。
  • 本站管理员有权保留或删除评论内容。