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

简介:
在一些系统,为了特定目的,经常要求程序隐藏起来运行,例如DCS(集散控制系统)中的后台监控系统、木马控制程序、源码防拷贝等,以减少被发现、截杀和反汇编的风险。这种功能模块要求程序在运行期间不仅不会在桌面出现,也不允许被操作者从任务管理器列表中发现。 

  程序隐形的原理 

  对于一个隐形程序而言,最基本的要求是: 

  1. 不在桌面出现界面; 

  2. 不在任务栏出现图标; 

  3. 程序名从任务管理器名单中消失。 

  对于上述第一点,可以将Form的Visible属性设为False。 

  要将图标从任务栏中屏蔽掉,可以把Form的ShowInTaskBar改为False。 

  在Windows环境下,可以调用WIN API函数中的RegisterviceProcess来实现第三个要求。 

  上述功能,不论用VC、Delphi、VB,还是PB等任何一种高级编程语言都是比较容易实现的。 

  隐形功能多用于木马程序,但木马程序在许多国家和地区是不合法的,为便于理解,本文用VB结合一个程序防拷贝的实例来讲解。通过获取软件安装路径所在磁盘序列号(磁盘ID),用做对合法用户的判断。以下程序的目的是用于讲解隐形程序的编制和应用,对程序防拷贝内容作了一定程度的简化。 

  程序隐形的示例 

  程序的具体编制操作如下: 

  1. 在VB6.0编程环境中,新建一个工程Project1。 

  2. 在Project1中添加模块Modulel,在工程属性中将工程名称改为HiddenMen,应用程序标题也改为HiddenMen(以下程序都经过实际运行测试,可以原样复制使用)。 

  在模块Module1中加入如下声明: 

Public Declare Function GetCurrentProcessId Lib “kernel32” () As Long 
’获得当前进程ID函数的声明 
Public Declare Function RegisterServiceProcess Lib “kernel32” (ByVal ProcessId As Long, ByVal ServiceFlags As Long) As Long 
’在系统中注册当前进程ID函数的声明

  3. 在Project1中新建一个窗体Form1,设置Form1的属性: 

form1.Visible=False 
form1.ShowInTaskBar=False

  在代码窗口添加如下代码: 

Private Declare Function GetDriveType Lib “kernel32” Alias “GetDriveTypeA” (ByVal nDrive As String) As Long 
’获得当前驱动器类型函数的声明 
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 
’获得当前驱动器信息函数的声明 
Private Sub Form_Load() 
Dim drive_no As Long, drive_flag As Long 
Dim drive_chr As String, drive_disk As String 
Dim serial_no As Long, kkk As Long 
Dim stemp3 As String, dflag As Boolean 
Dim strlabel As String, strtype As String,strc As Long 
RegisterServiceProcess GetCurrentProcessId, 1 ’ 从系统中取消当前进程 
strlabel = String(255, Chr(0)) 
strtype = String(255, Chr(0)) 
stemp3 = “172498135” ’这是作者C盘的序列号(十进制),读者可根据自己情况更改。 
dflag = False 
For drive_no = 0 To 25 
 drive_disk = Chr(drive_no + 67) 
 drive_chr = drive_disk & “:\” 
 drive_flag = GetDriveType(drive_chr) 
 If drive_flag = 3 Then 
   kkk = GetVolumeInformation(drive_chr, strlabel, Len(strlabel), serial_no, 0, 0, strtype, Len(strtype)) ’通过GetVolumeInformation获得磁盘序列号 
 Select Case drive_no 
   Case 0 
   strc = serial_no 
 End Select 
 If serial_no = stemp3 Then 
   dflag = True 
   Exit For 
 End If 
End If 
Next drive_no 
If drive_no = 26 And dflag = False Then ’非法用户 
 GoTo err: 
End If 
MsgBox (“HI,合法用户!”) 
Exit Sub 
err: 
 MsgBox (“错误!你的C:盘ID号是” & strc) 
End Sub 
Private Sub Form_Unload(Cancel As Integer) 
RegisterServiceProcess GetCurrentProcessId, 0 ’从系统中取消当前程序的进程 
End Sub

  将上述程序代码编译后运行,在出现类似“错误!你的C盘ID号是172498135”对话框时,按下Ctrl+Alt+Del键,看看程序名叫“HiddenMen”是否在任务管理器名单列表里。如果把上述程序稍加改动,可以加到自己特定的程序中去。该程序在隐形运行之中,不知不觉就完成了预定功能。 

  以上程序在简体中文Windows 98和VB 6.0环境中调试通过。


本文转自sucre03 51CTO博客,原文链接:http://blog.51cto.com/sucre/354211,如需转载请自行联系原作者

相关文章
|
Web App开发 索引
正则表达式匹配域名、网址、url
DNS规定,域名中的标号都由英文字母和数字组成,每一个标号不超过63个字符,也不区分大小写字母。标号中除连字符(-)外不能使用其他的标点符号。级别最低的域名写在最左边,而级别最高的域名写在最右边。由多个标号组成的完整域名总共不超过255个字符。
31266 0
|
负载均衡 安全 API
SDN网络架构分为哪三层
SDN软件定义网络是一种创新的网络架构,旨在提供更灵活、可编程和智能的网络管理。SDN的设计理念是通过将网络控制平面和数据平面分离,实现对网络行为的集中控制和编程。
|
Shell Android开发
Android系统 init.rc文件详解
Android系统 init.rc文件详解
2025 0
|
3月前
|
机器学习/深度学习 传感器 编解码
DINOv3上手指南:改变视觉模型使用方式,一个模型搞定分割、检测、深度估计
DINOv3是Meta推出的自监督视觉模型,支持冻结主干、仅训练轻量任务头即可在分割、深度估计等任务上达到SOTA,极大降低训练成本。其密集特征质量优异,适用于遥感、工业检测等多领域,真正实现“一个模型走天下”。
2585 2
DINOv3上手指南:改变视觉模型使用方式,一个模型搞定分割、检测、深度估计
|
10月前
|
JSON 文字识别 测试技术
Qwen2.5-VL Cookbook来啦!手把手教你怎么用好视觉理解模型!
今天,Qwen团队发布了一系列展示 Qwen2.5-VL 用例的Notebook,包含本地模型和 API 的使用。
2944 22
|
5月前
|
前端开发 JavaScript 编译器
React编程新手入门实践教程
本书深入解析React核心思想与设计哲学,涵盖组件化思维、虚拟DOM原理及JSX本质,探讨函数组件与类组件特性,详解状态管理、生命周期控制及事件处理机制,帮助开发者掌握高效构建用户界面的技巧。
162 0
|
网络协议
使用ensp搭建路由拓扑,并使用ospf协议实现网络互通实操
使用ensp搭建路由拓扑,并使用ospf协议实现网络互通实操
373 0
|
供应链 监控 区块链
确保区块链供应链的透明度和可追溯性,我们可以从以下几个方面进行
**区块链提升供应链透明度与可追溯性:** - 建立不可篡改记录,保证数据真实完整。 - 实现实时监控,加快问题响应,提高效率。 - 追溯产品全程,消费者可验证来源,增强信任。 - 促进信息共享,降低沟通成本,提升协同。 - 防止欺诈串通,确保供应链诚信与透明。 这些措施通过区块链技术的应用,优化供应链管理,降低成本,增强市场信心。
java实现(燃油车车牌生成)
java实现(燃油车车牌生成)
|
调度 UED 开发者
【鸿蒙软件开发】UIAbility组件概况、生命周期与启动模式
【鸿蒙软件开发】UIAbility组件概况、生命周期与启动模式
1536 0
【鸿蒙软件开发】UIAbility组件概况、生命周期与启动模式