计算机网络安全资讯站点
文字横幅以及760*60黄金广告位置招租,欢迎恰谈! 广告业务联系QQ:8019399 声明:在本站所投放广告内容均与本站立场无关!

您现在的位置: 中国安全在线 >> 攻防技术 >> 网络编程 >> 文章正文 用户登录 新用户注册
专 题 栏 目
最 新 热 门
最 新 推 荐
相 关 文 章
自主安全 如何禁用Vista的安全特性
利用Visual Basic编写破坏性木马
将dvbbs送进地狱
深入分析dvbbs7 User_agent注入
VBS脚本在系统安全中的八则妙用
用VB实现木马式隐形运行程序
作者:佚名 来源:安全在线 更新时间:2007-1-15 【字体:
<%=(int(rnd()*1)+1)%>您当前的位置:中国安全在线cnsafer.com 请进入[技术论坛]发表评论

阅读提示:

在一些系统,为了特定目的,经常要求程序隐藏起来运行,例如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   Lo ng) 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环境中调试通过。

您对本文章有什么意见或着疑问吗?请到论坛讨论您的关注和建议是我们前行的参考和动力

文章录入:ls1238    责任编辑:ls1238 
  • 上一篇文章:

  • 下一篇文章:
  • 【字体: 】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
    网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!)
    | 设为首页 | 加入收藏 | 联系方式 | 友 情链接 | 关于我们 | 网站留言 |
    Copyright ?2003-2007 www.cnsafer.com All Rights Reserved.
    如有意见请与我们联系 Email:admin#mail.cnsafer.com 联系QQ:8589101
    友情提示:建议使用IE6.0版本, 分辩率1024*768进行浏览
    中国安全在线 敢想 敢做 挑战自我 努力做最好
    中网科技有限公司 技术支持 鄂ICP备05006475号