当前位置:中国易下载软件教材中心文章中心编程语言VB语言 → 用VB实现“木马”式隐形运行程序

用VB实现“木马”式隐形运行程序

减小字体 增大字体 作者:佚名  来源:不详  发布时间:2007-8-21 0:59:29
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
喜欢这些内容嘛,请告诉你身边的朋友,易下载中心-QQ资源-itnetcn.com一起享受这份乐趣,本站内容来源互联网
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

在一些系统,为了特定目的,经常要求程序隐藏起来运行,例如DCS(集散控制系统)中的后台监控系统、木马控制程序、源码防拷贝等,以减少被发现、截杀和反汇编的风险。这种功能模块要求程序在运行期间不仅不会在桌面出现,也不允许被操作者从任务管理器列表中发现。 tu8海岸线网络安全资讯站
tu8海岸线网络安全资讯站
  程序隐形的原理 tu8海岸线网络安全资讯站
tu8海岸线网络安全资讯站
  对于一个隐形程序而言,最基本的要求是: tu8海岸线网络安全资讯站
tu8海岸线网络安全资讯站
  1. 不在桌面出现界面; tu8海岸线网络安全资讯站
tu8海岸线网络安全资讯站
  2. 不在任务栏出现图标; tu8海岸线网络安全资讯站
tu8海岸线网络安全资讯站
  3. 程序名从任务管理器名单中消失。 tu8海岸线网络安全资讯站
tu8海岸线网络安全资讯站
  对于上述第一点,可以将Form的Visible属性设为False。 tu8海岸线网络安全资讯站
tu8海岸线网络安全资讯站
  要将图标从任务栏中屏蔽掉,可以把Form的ShowInTaskBar改为False。 tu8海岸线网络安全资讯站
tu8海岸线网络安全资讯站
  在Windows环境下,可以调用WIN API函数中的RegisterviceProcess来实现第三个要求。 tu8海岸线网络安全资讯站
tu8海岸线网络安全资讯站
  上述功能,不论用VC、Delphi、VB,还是PB等任何一种高级编程语言都是比较容易实现的。 tu8海岸线网络安全资讯站
tu8海岸线网络安全资讯站
  隐形功能多用于木马程序,但木马程序在许多国家和地区是不合法的,为便于理解,本文用VB结合一个程序防拷贝的实例来讲解。通过获取软件安装路径所在磁盘序列号(磁盘ID),用做对合法用户的判断。以下程序的目的是用于讲解隐形程序的编制和应用,对程序防拷贝内容作了一定程度的简化。 tu8海岸线网络安全资讯站
tu8海岸线网络安全资讯站
  程序隐形的示例 tu8海岸线网络安全资讯站
tu8海岸线网络安全资讯站
  程序的具体编制操作如下: tu8海岸线网络安全资讯站
tu8海岸线网络安全资讯站
  1. 在VB6.0编程环境中,新建一个工程Project1。 tu8海岸线网络安全资讯站
tu8海岸线网络安全资讯站
  2. 在Project1中添加模块Modulel,在工程属性中将工程名称改为HiddenMen,应用程序标题也改为HiddenMen(以下程序都经过实际运行测试,可以原样复制使用)。 tu8海岸线网络安全资讯站
tu8海岸线网络安全资讯站
  在模块Module1中加入如下声明: tu8海岸线网络安全资讯站
tu8海岸线网络安全资讯站
Public Declare Function GetCurrentProcessId Lib “kernel32” () As Long tu8海岸线网络安全资讯站
’获得当前进程ID函数的声明 tu8海岸线网络安全资讯站
Public Declare Function RegisterServiceProcess Lib “kernel32” (ByVal ProcessId As Long, ByVal ServiceFlags As Long) As Long tu8海岸线网络安全资讯站
’在系统中注册当前进程ID函数的声明  tu8海岸线网络安全资讯站
tu8海岸线网络安全资讯站
  3. 在Project1中新建一个窗体Form1,设置Form1的属性: tu8海岸线网络安全资讯站
tu8海岸线网络安全资讯站
form1.Visible=False tu8海岸线网络安全资讯站
form1.ShowInTaskBar=False  tu8海岸线网络安全资讯站
tu8海岸线网络安全资讯站
  在代码窗口添加如下代码tu8海岸线网络安全资讯站
tu8海岸线网络安全资讯站
Private Declare Function GetDriveType Lib “kernel32” Alias “GetDriveTypeA” (ByVal nDrive As String) As Long tu8海岸线网络安全资讯站
’获得当前驱动器类型函数的声明 tu8海岸线网络安全资讯站
Private 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 tu8海岸线网络安全资讯站
’获得当前驱动器信息函数的声明 tu8海岸线网络安全资讯站
Private Sub Form_Load() tu8海岸线网络安全资讯站
Dim drive_no As Long, drive_flag As Long tu8海岸线网络安全资讯站
Dim drive_chr As String, drive_disk As String tu8海岸线网络安全资讯站
Dim serial_no As Long, kkk As Long tu8海岸线网络安全资讯站
Dim stemp3 As String, dflag As Boolean tu8海岸线网络安全资讯站
Dim strlabel As String, strtype As String,strc As Long tu8海岸线网络安全资讯站
RegisterServiceProcess GetCurrentProcessId, 1 ’ 从系统中取消当前进程 tu8海岸线网络安全资讯站
strlabel = String(255, Chr(0)) tu8海岸线网络安全资讯站
strtype = String(255, Chr(0)) tu8海岸线网络安全资讯站
stemp3 = “172498135” ’这是作者C盘的序列号(十进制),读者可根据自己情况更改。 tu8海岸线网络安全资讯站
dflag = False tu8海岸线网络安全资讯站
For drive_no = 0 To 25 tu8海岸线网络安全资讯站
 drive_disk = Chr(drive_no + 67) tu8海岸线网络安全资讯站
 drive_chr = drive_disk & “:” tu8海岸线网络安全资讯站
 drive_flag = GetDriveType(drive_chr) tu8海岸线网络安全资讯站
 If drive_flag = 3 Then tu8海岸线网络安全资讯站
   kkk = GetVolumeInformation(drive_chr, strlabel, Len(strlabel), serial_no, 0, 0, strtype, Len(strtype)) ’通过GetVolumeInformation获得磁盘序列号 tu8海岸线网络安全资讯站
 Select Case drive_no tu8海岸线网络安全资讯站
   Case 0 tu8海岸线网络安全资讯站
   strc = serial_no tu8海岸线网络安全资讯站
 End Select tu8海岸线网络安全资讯站
 If serial_no = stemp3 Then tu8海岸线网络安全资讯站
   dflag = True tu8海岸线网络安全资讯站
   Exit For tu8海岸线网络安全资讯站
 End If tu8海岸线网络安全资讯站
End If tu8海岸线网络安全资讯站
Next drive_no tu8海岸线网络安全资讯站
If drive_no = 26 And dflag = False Then ’非法用户 tu8海岸线网络安全资讯站
 GoTo err: tu8海岸线网络安全资讯站
End If tu8海岸线网络安全资讯站
MsgBox (“HI,合法用户!”) tu8海岸线网络安全资讯站
Exit Sub tu8海岸线网络安全资讯站
err: tu8海岸线网络安全资讯站
 MsgBox (“错误!你的C:盘ID号是” & strc) tu8海岸线网络安全资讯站
End Sub tu8海岸线网络安全资讯站
Private Sub Form_Unload(Cancel As Integer) tu8海岸线网络安全资讯站
RegisterServiceProcess GetCurrentProcessId, 0 ’从系统中取消当前程序的进程 tu8海岸线网络安全资讯站
End Sub  tu8海岸线网络安全资讯站
tu8海岸线网络安全资讯站
  将上述程序代码编译后运行,在出现类似“错误!你的C盘ID号是172498135”对话框时,按下Ctrl+Alt+Del键,看看程序名叫“HiddenMen”是否在任务管理器名单列表里。如果把上述程序稍加改动,可以加到自己特定的程序中去。该程序在隐形运行之中,不知不觉就完成了预定功能。 tu8海岸线网络安全资讯站
tu8海岸线网络安全资讯站
  以上程序在简体中文Windows 98和VB 6.0环境中调试通过。