转至繁体中文版     | 网站首页 | 图文教程 | 资源下载 | 站长博客 | 图片素材 | 武汉seo | 武汉网站优化 | 
最新公告:     敏韬网|教学资源学习资料永久免费分享站!  [mintao  2008年9月2日]        
您现在的位置: 学习笔记 >> 图文教程 >> 软件开发 >> VB.NET程序 >> 正文
小弟为共享软件作者制作的管理软件注册的动态链接库         ★★★★

小弟为共享软件作者制作的管理软件注册的动态链接库

作者:闵涛 文章来源:闵涛的学习笔记 点击数:2168 更新时间:2009/4/23 18:58:51
 

小弟为共享软件作者制作的管理软件注册的动态链接库

 

作为共享软件作者,注册码被非法公布是件令你十分头疼的事情。小弟制作了这么一个类库。希望能有所帮助。它每次在RegestCheck被执行一遍的时候生成动态的用户名及密码,并保存入注册表。但软件已经注册的话则不改变原来的注册信息。所以,盗用注册码对它是没用的。

 

它有三个方法,四个属性。RegestCheck用来检查您的共享软件是否注册,Regest用来注册您的共享软件。GetNamePassword是为Name,Password属性赋一个合法的值。Regested 属性是保存共享软件是否注册过的信息的。RegestedKey是您的软件在注册表LOCAL_MACHINE主键中注册的键名。至于RegestName,RegestPassword就是保存合法的用户名及密码的了。

 

例子程序如下:

Option Explicit

 

Private Sub Form_Load()

 

 Dim Temp As ClassRegest   ‘请先在”引用”中引用这个类(动态链接库)

 

 Set Temp = New ClassRegest

 

 Temp.RegestKey = "Software\RegestTest"   ‘设置你的软件在注册表中注册的键名

 Temp.Regestcheck   ‘判断是否注册, 判断结果保存在Regested属性中

 ‘必须先赋值RegestKey及执行一遍RegestCheck,其它的属性及方法才能被正确执行

 

 MsgBox "Regeted is " & Temp.Regested

 

 Temp.GetNamePassword ’通过一定的算法为RegestName,RegestPassword赋于一个合法的值

 MsgBox "name is: " & Temp.RegestName

 MsgBox "password is: " & Temp.RegestPassword

 

 Temp.Regest  ‘如果共享软件没有注册,则注册这个软件

 

 Set Temp=Nothing

 

End Sub

 

现在把这个DLL动态链接库的源代码提供如下:

(VB6.0测试通过)

 

Option Explicit

 

Private Const HKEY_LOCAL_MACHINE  As Long = &H80000002 ''''注册表函数的几个参数

Private Const KEY_QUERY_VALUE  As Long = &H1

Private Const KEY_SET_VALUE  As Long = &H2

Private Const REG_SZ  As Long = 1

 

Private Declare Function RegOpenKeyEx Lib "advapi32.dll" Alias "RegOpenKeyExA" (ByVal hKey As Long, ByVal lpSubKey As String, ByVal ulOptions As Long, ByVal samDesired As Long, phkResult As Long) As Long

Private Declare Function RegQueryValueEx Lib "advapi32.dll" Alias "RegQueryValueExA" (ByVal hKey As Long, ByVal lpValueName As String, ByVal lpReserved As Long, lpType As Long, ByVal lpData As String, lpcbData As Long) As Long

Private Declare Function RegSetValueEx Lib "advapi32.dll" Alias "RegSetValueExA" (ByVal hKey As Long, ByVal lpValueName As String, ByVal Reserved As Long, ByVal dwType As Long, ByVal lpData As String, ByVal cbData As Long) As Long

Private Declare Function RegCloseKey Lib "advapi32.dll" (ByVal hKey As Long) As Long

 

Private m_Regested As Boolean ''''是否注册属性

Private m_RegestKey As String ''''注册表中的子键名

Private m_Name As String      ''''用户名属性

Private m_Password As String  ''''密码属性

 

Private nCount As Integer     ''''用来临时计数

Private lReturn As Long       ''''接收返回值

Private Const sTarget As String = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ,.;:" ''''用来生成随机文本

Private FSO As FileSystemObject  ''''用来产生随机文件的文件系统对象

Private FSOFile As File

Private FSOString As TextStream

 

Private Sub Class_Initialize()

 

 m_Regested = False

 m_RegestKey = ""

 

End Sub

 

Public Sub RegestCheck()

 

 Dim sName As String * 9      ''''保存注册表中读出的用户名

 Dim sPassword As String * 26 ''''保存注册表中读出的密码

 Dim hEditKey As Long         ''''保存打开的注册表键的句柄

 Dim lRegOpenError As Long    ''''保存打开注册表某主键的返回值

 

 lRegOpenError = RegOpenKeyEx(HKEY_LOCAL_MACHINE, m_RegestKey, 0, KEY_QUERY_VALUE, hEditKey)

 

 If lRegOpenError <> 0 Then   ''''如果打开出错

  MsgBox "Open Reg Error!Terminate!Please examine RegestKey."

  Exit Sub

 End If

 

 lReturn = RegQueryValueEx(hEditKey, "Name", 0, REG_SZ, sName, 9)

 If lReturn = 2 Then          ''''如果Name键值不存在

  GoTo FORNEXT

 End If

 lReturn = RegQueryValueEx(hEditKey, "Password", 0, REG_SZ, sPassword, 26)

 If lReturn = 2 Then

  GoTo FORNEXT

 End If

 

 If KeyCheck(Left(sName, 8), Left(sPassword, 25)) = True Then

  m_Regested = True   ''''KeyCheck检查Name和Password是否为合法,合法则m_regested被设为True

  Exit Sub

 End If

 

FORNEXT:

 m_Regested = False   ''''未通过KeyCheck则m_Regested设为否

 

 Randomize            ''''初始化随机数生成器

 

 Dim hFileNumber As Integer          ''''打开当前目录下的Key.dat文件,该文件用来保存用以生成Name及Password的一个随机字符串

 hFileNumber = FreeFile

 If Right(App.Path, 1) = "\" Then

  Open App.Path & "Key.dat" For Binary As hFileNumber

 Else

  Open App.Path & "\Key.dat" For Binary As hFileNumber

 End If

 

 Dim iRandom As Integer                   ''''生成随机字符数组baRandom()

 Dim baRandom(1 To 100) As Byte

 Dim iTemp As Integer

 Dim iNameLength As Integer

 Dim iPasswordLength As Integer

 Dim iKeyLength As Integer

 iNameLength = 0

 iPasswordLength = 0

 For nCount = 1 To 100 Step 3

  If iNameLength = 8 Then

   baRandom(nCount) = &HFF

   nCount = nCount + 1

   iNameLength = 9

  End If

  baRandom(nCount) = CByte(CStr(Int(32 * Rnd)))

  iTemp = (CInt(baRandom(nCount)) + 1) ^ 2 - CInt(baRandom(nCount)) ^ 2

  baRandom(nCount + 1) = CByte(CInt(iTemp * Rnd))

  If iNameLength < 8 Then

   baRandom(nCount + 2) = CByte(Int((8 - iNameLength) * Rnd) + 1)

   iNameLength = iNameLength + CInt(baRandom(nCount + 2))

  Else

   If iPasswordLength < 25 Then

    baRandom(nCount + 2) = CByte(Int((25 - iPasswordLength) * Rnd + 1))

    iPasswordLength = iPasswordLength + CInt(baRandom(nCount + 2))

   Else

    iKeyLength = nCount - 1

    nCount = 100

   End If

  End If

 Next

  

 For nCount = 1 To iKeyLength            ''''在Key.dat中写入baRandom()

  Put #hFileNumber, nCount, baRandom(nCount)

 Next

 

 Close #hFileNumber

 

 Set FSO = CreateObject("Scripting.FileSystemObject")  ''''生成一个1024字节的随机字符组成的ASIIC文件

 If Right(App.Path, 1) = "\" Then

  If FSO.FileExists(App.Path & "Value.dat") Then

   Set FSOFile = FSO.GetFile(App.Path & "Value.dat")

&

[1] [2] [3]  下一页


没有相关教程
教程录入:mintao    责任编辑:mintao 
  • 上一篇教程:

  • 下一篇教程:
  • 【字体: 】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
      注:本站部分文章源于互联网,版权归原作者所有!如有侵权,请原作者与本站联系,本站将立即删除! 本站文章除特别注明外均可转载,但需注明出处! [MinTao学以致用网]
      网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!)

    同类栏目
    · C语言系列  · VB.NET程序
    · JAVA开发  · Delphi程序
    · 脚本语言
    更多内容
    热门推荐 更多内容
  • 没有教程
  • 赞助链接
    更多内容
    闵涛博文 更多关于武汉SEO的内容
    500 - 内部服务器错误。

    500 - 内部服务器错误。

    您查找的资源存在问题,因而无法显示。

    | 设为首页 |加入收藏 | 联系站长 | 友情链接 | 版权申明 | 广告服务
    MinTao学以致用网

    Copyright @ 2007-2012 敏韬网(敏而好学,文韬武略--MinTao.Net)(学习笔记) Inc All Rights Reserved.
    闵涛 投放广告、内容合作请Q我! E_mail:admin@mintao.net(欢迎提供学习资源)

    站长:MinTao ICP备案号:鄂ICP备11006601号-18

    闵涛站盟:医药大全-武穴网A打造BCD……
    咸宁网络警察报警平台