開始之前先簡單說明下cmd文件和bat文件的區(qū)別:在本質(zhì)上兩者沒有區(qū)別,都是簡單的文本編碼方式,都可以用記事本創(chuàng)建、編輯和查看。兩者所用的命令行代碼也是共用的,只是cmd文件中允許使用的命令要比bat文件多。cmd文件只有在windows2000以上的系統(tǒng)中才能運行,而bat文件則沒有這個限制。從它們的文件描述中也可以看出以上的區(qū)別:cmd文件的描述是“windows nt命令腳本”, bat文件的描述是“ms dos批處理文件”
如果沒有一定的相關(guān)知識恐怕不容易看懂和理解批處理文件,也就更談不上自己動手編寫了.批處理文件是無格式的文本文件,它包含一條或多條命令。它的文件擴展名為 .bat 或 .cmd。在命令提示下鍵入批處理文件的名稱,或者雙擊該批處理文件,系統(tǒng)就會調(diào)用cmd.exe按照該文件中各個命令出現(xiàn)的順序來逐個運行它們。使用批處理文件(也被稱為批處理程序或腳本),可以簡化日?;蛑貜托匀蝿铡.斎晃覀兊倪@個版本的主要內(nèi)容是介紹批處理在入侵中一些實際運用,例如我們后面要提到的用批處理文件來給系統(tǒng)打補丁、批量植入后門程序等。下面就開始我們批處理學習之旅吧。
打開回顯或關(guān)閉請求回顯功能,或顯示消息。如果沒有任何參數(shù),echo 命令將顯示當前回顯設置。
語法
echo [{ on|off }] [message]
Sample 1 :
@echooff
echohello world
Sample 2 :
@echo off
echo 1
echo.
echo 2
echo on
echo 3
pause
在實際應用中我們會把這條命令和重定向符號(也稱為管道符號,一般用> >> ^)結(jié)合來實現(xiàn)輸入一些命令到特定格式的文件中.這將在以后的例子中體現(xiàn)出來。
c:\>dir *.txt > 1.txt
c:\>dir *.txt >> 1.txt
表示不顯示@后面的命令,在入侵過程中(例如使用批處理來格式化敵人的硬盤)自然不能讓對方看到你使用的命令啦。
Sample:@echo off
指定跳轉(zhuǎn)到標簽,找到標簽后,程序?qū)⑻幚韽南乱恍虚_始的命令。
語法:goto label (label是參數(shù),指定所要轉(zhuǎn)向的批處理程序中的行。)
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命令就是根據(jù)這個:來尋找下一步跳到到那里。最好有一些說明這樣你別人看起來才會理解你的意圖啊。
注釋命令,在C語言中相當與/*--------*/,它并不會被執(zhí)行,只是起一個注釋的作用,便于別人閱讀和你自己日后修改。
Rem Message
Sample:@Rem Here is the description.
運行 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
在這個例子中,驅(qū)動器 A 中磁盤上的所有文件均復制到d:\\back中。顯示的注釋提示您將另一張磁盤放入驅(qū)動器 A 時,pause 命令會使程序掛起,以便您更換磁盤,然后按任意鍵繼續(xù)處理。
從一個批處理程序調(diào)用另一個批處理程序,并且不終止父批處理程序。call 命令接受用作調(diào)用目標的標簽。如果在腳本或批處理文件外使用 call,它將不會在命令行起作用
語法
call [[Drive:][Path] FileName [BatchParameters]] [:label [arguments]]
參數(shù)
[Drive: }[Path] FileName
指定要調(diào)用的批處理程序的位置和名稱。filename 參數(shù)必須具有 .bat 或 .cmd 擴展名。
Start
啟動單獨的“命令提示符”窗口來運行指定程序或命令。如果在沒有參數(shù)的情況下使用,start 將打開第二個命令提示符窗口。
語法
start ["title"] [/dPath] [/min] [/max] [{/separate |/shared}] [{/low | /normal | /high | /realtime | /abovenormal | belownormal}][/wait] [/B] [FileName] [parameters]
參數(shù)
"title" 指定在“命令提示符”窗口標題欄中顯示的標題。
/dpatch 指定啟動目錄。
/i 將 Cmd.exe 啟動環(huán)境傳送到新的“命令提示符”窗口。
/min 啟動新的最小化窗口。
/max 啟動新的最大化窗口。
/separate 在單獨的內(nèi)存空間啟動 16 位程序。
/shared 在共享的內(nèi)存空間啟動 16 位程序。
/low 以空閑優(yōu)先級啟動應用程序。
/normal 以一般優(yōu)先級啟動應用程序。
/high 以高優(yōu)先級啟動應用程序。
/realtime 以實時優(yōu)先級啟動應用程序。
/abovenormal 以超出常規(guī)優(yōu)先級的方式啟動應用程序。
/belownormal 以低出常規(guī)優(yōu)先級的方式啟動應用程序。
/wait 啟動應用程序,并等待其結(jié)束。
/b 啟動應用程序時不必打開新的“命令提示符”窗口。除非應用程序啟用 CTRL+C,否則將忽略 CTRL+C 操作。使用 CTRL+BREAK 中斷應用程序。
非執(zhí)行文件只要將文件名作為命令鍵入,即可通過其文件關(guān)聯(lián)運行該文件。有關(guān)使用 assoc 和 ftype 在命令腳本中創(chuàng)建這些關(guān)聯(lián)的詳細信息,請參閱“”。
在運行的命令的第一個標記為“CMD”字符串但不包括擴展名或路徑限定符時,“CMD”將被 COMSPEC 變量的值取代。這樣可以防止用戶從當前目錄選取 cmd。
當您運行 32 位圖形用戶界面 (GUI) 應用程序時,cmd 不會在返回到命令提示符之前等待應用程序退出。如果從命令腳本運行應用程序,則不會發(fā)生這種新情況。在運行的命令中第一個符號不包括擴展名的情況下,Cmd.exe 使用 PATHEXT 環(huán)境變量的值確定要查找的擴展名以及查找順序。PATHEXT 變量的默認值為:COM;.EXE;.BAT;.CMD(語法與 PATH 變量相同,使用分號分開不同元素)。當您搜索可執(zhí)行文件且在任何擴展名上都沒有匹配項時,start 將搜索目錄名。
具體例子:
說明:如果你所在程序的路徑中帶有空格,那么必須用“”把路徑括起來,否則系統(tǒng)會提示找不到XX文件,另外,在運行某些程序時,需在路徑的前面加一對空白的“”,表示創(chuàng)建一個空白的窗口,它指向的程序是XXXXXXXX。還有就是別忘了空格。
當我想運行位于“D:\draw\”的“photoshop.exe”使,應該使用以下命令:
start “”“D:\draw\photoshop.exe” 表示以常規(guī)窗口運行程序
如果想讓程序以最大化窗口運行,則使用以下命令:
start /max“”“D:\draw\photoshop.exe” 表示以最大化窗口運行程序
最小化這是這樣:
start /min "" "D:\draw\photoshop.exe" 表示以最小化窗口運行程序
等待某個程序允許完畢,也就是窗口關(guān)閉后,再打開下一個程序這可以這樣:
start /w "" "D:\draw\photoshop.exe"
start "" cmd.exe
start /min “” “e:\t.cmd”
choice 使用此命令可以讓用戶輸入一個字符,從而運行不同的命令。使用時應該加/c:參數(shù),c:后應寫提示可輸入的字符,之間無空格。它的返回碼為1234……
如: choice /c:dme defrag,mem,end
將顯示
defrag,mem,end[D,M,E]?
Sample:
Sample.bat的內(nèi)容如下:
@echo off
choice /c:dme defrag,mem,end
if errorlevel 3 goto defrag (應先判斷數(shù)值最高的錯誤碼)
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表示執(zhí)行標號為defrag的程序段,m表示執(zhí)行標號為mem的程序段,e表示執(zhí)行標號為end的程序段,每個程序段最后都以goto end將程序跳到end標號處,然后程序?qū)@示good bye,文件結(jié)束。
if 表示將判斷是否符合規(guī)定的條件,從而決定執(zhí)行不同的命令。 有三種格式:
1、if "參數(shù)" == "字符串" 待執(zhí)行的命令
參數(shù)如果等于指定的字符串,則條件成立,運行命令,否則運行下一句。(注意是兩個等號)
如if "%1"=="a" format a:
if { %1 }=={ } goto noparms
if { %2 }=={ } goto noparms
2、if exist 文件名 待執(zhí)行的命令
如果有指定的文件,則條件成立,運行命令,否則運行下一句
如if exist config.sys edit config.sys
3、if errorlevel / if not errorlevel 數(shù)字 待執(zhí)行的命令
如果返回碼等于指定的數(shù)字,則條件成立,運行命令,否則運行下一句。
如if errorlevel 2 goto x2
DOS程序運行時都會返回一個數(shù)字給DOS,稱為錯誤碼errorlevel或稱返回碼,常見的返回碼為0、1。
FOR這條命令基本上都被用來處理文本,但還有其他一些好用的功能!
看看他的基本格式(這里我引用的是批處理中的格式,直接在命令行只需要一個%號)
FOR 參數(shù) %%變量名 IN (相關(guān)文件或命令) DO 執(zhí)行的命令
參數(shù):FOR有4個參數(shù) /d /l /r /f 他們的作用我在下面用例子解釋
%%變量名 :這個變量名可以是小寫a-z或者大寫A-Z,他們區(qū)分大小寫,FOR會把每個讀取到的值給他;
IN:命令的格式,照寫就是了;
(相關(guān)文件或命令) :FOR要把什么東西讀取然后賦值給變量,看下面的例子
do:命令的格式,照寫就是了!
執(zhí)行的命令:對每個變量的值要執(zhí)行什么操作就寫在這.
可以在CMD輸入for /?看系統(tǒng)提供的幫助!對照一下
FOR %%variable IN (set) DO command [command-parameters]
%%variable 指定一個單一字母可替換的參數(shù)。
(set) 指定一個或一組文件。可以使用通配符。
command 指定對每個文件執(zhí)行的命令。
command-parameters
為特定命令指定參數(shù)或命令行開關(guān)。
現(xiàn)在開始講每個參數(shù)的意思
/d
僅為目錄
如果 Set (也就是我上面寫的 "相關(guān)文件或命令") 包含通配符(* 和 ?),將對與 Set 相匹配的每個目
錄(而不是指定目錄中的文件組)執(zhí)行指定的 Command。
系統(tǒng)幫助的格式:FOR /D%%variable IN (set) DO command
他主要用于目錄搜索,不會搜索文件,看這樣的例子
@echo off
for /d %%i in (*) do @echo %%i
pause
把他保存放在C盤根目錄執(zhí)行,就會把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盤下執(zhí)行,會顯示什么呢?自己看吧!
/D參數(shù)只能顯示當前目錄下的目錄名字,這個大家要注意!
/R
遞歸
進入根目錄樹[Drive:]Path,在樹的每個目錄中執(zhí)行for 語句。如果在 /R 后沒有指定目錄,則認為是
當前目錄。如果 Set 只是一個句點 (.),則只枚舉目錄樹。
系統(tǒng)幫助的格式:FOR /R[[drive:]path] %%variable IN (set) DO command
上面我們知道,/D只能顯示當前路徑下的目錄名字,那么現(xiàn)在這個/R也是和目錄有關(guān),他能干嘛呢?放心他比
/D強大多了!
他可以把當前或者你指定路徑下的文件名字全部讀取,注意是文件名字,有什么用看例子!
@echo off
for /r c:\ %%i in (*.exe) do @echo %%i
pause
咋們把這個BAT保存到D盤隨便哪里然后執(zhí)行,我會就會看到,他把C盤根目錄,和每個目錄的子目錄下面全部
的EXE文件都列出來了,這里的c:\就是目錄了。
再來一個
@echo off
for /r %%i in (*.exe) do @echo %%i
pause
參數(shù)不一樣了,這個命令前面沒加那個C:\也就是搜索路徑,這樣他就會以當前目錄為搜索路徑,比如你這
個BAT你把他防災d:\test目錄下執(zhí)行,那么他就會把D:\test目錄和他下面的子目錄的全部EXE文件列出
來!!!
/L
迭代數(shù)值范圍
使用迭代變量設置起始值(Start#),然后逐步執(zhí)行一組范圍的值,直到該值超過所設置的終止值 (End#)
。/L 將通過對 Start# 與 End# 進行比較來執(zhí)行迭代變量。如果 Start# 小于 End#,就會執(zhí)行該命令。
如果迭代變量超過 End#,則命令解釋程序退出此循環(huán)。還可以使用負的 Step# 以遞減數(shù)值的方式逐步執(zhí)
行此范圍內(nèi)的值。例如,(1,1,5)生成序列 1 2 3 4 5,而 (5,-1,1) 則生成序列 (5 4 3 2 1)。語法是:
系統(tǒng)幫助的格式:for /L%% Variable in (Start#,Step#,End#) do Command
例如:
@echo off
for /l %%i in (1,1,5) do @echo %%i
pause
保存執(zhí)行看效果,他會打印從1 2 3 4 5 這樣5個數(shù)字
(1,1,5)這個參數(shù)也就是表示從1開始每次加1直到5終止!
再看這個例子
@echo off
for /l %%i in (1,1,5) do start cmd
pause
執(zhí)行后是不是嚇了一跳,怎么多了5個CMD窗口,呵呵!如果把那個 (1,1,5)改成 (1,1,65535)會有什么結(jié)果,
我先告訴大家,會打開65535個CMD窗口....這么多你不死機算你強!
當然我們也可以把那個startcmd改成md %%i 這樣就會建立指定個目錄了!!!名字為1-65535
看完這個被我賦予破壞性質(zhì)的參數(shù)后,我們來看最后一個參數(shù)
/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
這個可能是最常用的,也是最強的命令,主要用來處理文件和一些命令的輸出結(jié)果。
file代表一個或多個文件
string 代表字符串
command代表命令
["options"]可選
對于FOR /F %%i IN (file) DO command
file為文件名,按照官方的說法是,for會依次將file中的文件打開,并且在進行到下一個文件之前將每個文件讀取到內(nèi)存,按照每一行分成一個一個的元素,忽略空白的行,看個例子。
假如文件a.txt中有如下內(nèi)容:
第1行第1列第1行第2列第1行第3列
第2行第1列第2行第2列第2行第3列
第3行第1列第3行第2列第3行第3列
你想顯示a.txt中的內(nèi)容,會用什么命令呢?當然是type,type a.txt
for也可以完成同樣的命令:
for /f %%i in(a.txt) do echo %%i
還是先從括號執(zhí)行,因為含有參數(shù)/f,所以for會先打開a.txt,然后讀出a.txt里面的所有內(nèi)容,把它作為一個集合,并且以每一行作為一個元素,所以會產(chǎn)生這樣的集合,
{"第1行第1列第1行第2列第1行第3列", //第一個元素
"第2行第1列第2行第2列第2行第3列", //第二個元素
"第3行第1列第3行第2列第3行第3列"} //第三個元素
集合中只有3個元素,同樣用%%i依次代替每個元素,然后執(zhí)行do后面的命令。
具體過程:
用%%i代替"第1行第1列第1行第2列第1行第3列",執(zhí)行do后面的echo %%i,顯示"第1行第1列第1行第2列第1行第3列",
用%%i代替"第2行第1列第2行第2列第2行第3列",執(zhí)行echo %%i,顯示"第2行第1列第2行第2列第2行第3列",
依次,直到每個元素都代替完為止。
為了加強理解/f的作用,請執(zhí)行一下兩個命令,對比即可明白:
for/f %%i in (a.txt) do echo %%i //這個會顯示a.txt里面的內(nèi)容,因為/f的作用,會讀出a.txt中
的內(nèi)容。
for%%i in (a.txt) do echo %%i //而這個只會顯示a.txt這個名字,并不會讀取其中的內(nèi)容。
通過上面的學習,我們發(fā)現(xiàn)for /f會默認以每一行來作為一個元素,但是如果我們還想把每一行再分解更小的內(nèi)容,該怎么辦呢?不用擔心,for命令還為我們提供了更詳細的參數(shù),使我們將每一行分為更小的元素成為可能。
它們就是:delims和tokens
delims 用來告訴for每一行應該拿什么作為分隔符,默認的分隔符是空格和tab鍵
比如,還是上面的文件,我們執(zhí)行下面的命令:
for/f "delims= " %%i in (a.txt) do echo %%i
顯示的結(jié)果是:
第1行第1列
第2行第1列
第3行第1列
為什么是這樣的呢。因為這里有了delims這個參數(shù),=后面有一個空格,意思是再將每個元素以空格分割,默認是只取分割之后的第一個元素。
執(zhí)行過程是:
將第一個元素"第1行第1列第1行第2列第1行第3列"分成三個元素:"第1行第1列" "第1行第2列" "第1行第3列",它默認只取第一個,即"第1行第1列",然后執(zhí)行do后面的命令,依次類推。
但是這樣還是有局限的,如果我們想要每一行的第二列元素,那又如何呢?
這時候,tokens跳出來說,我能做到。
它的作用就是當你通過delims將每一行分為更小的元素時,由它來控制要取哪一個或哪幾個。
還是上面的例子,執(zhí)行如下命令:
for/f "tokens=2 delims= " %%i in (a.txt) do echo %%i
執(zhí)行結(jié)果:
第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
執(zhí)行結(jié)果為:
第1行第2列第1行第3列
第2行第2列第2行第3列
第3行第2列第3行第3列
對以通配符*,就是把這一行全部或者這一行的剩余部分當作一個元素了。
比如:
for/f "tokens=* delims= " %%i in (a.txt) do echo %%i
執(zhí)行結(jié)果為:
第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的執(zhí)行結(jié)果是一樣的。
再如:
for/f "tokens=2,* delims= " %%i in (a.txt) do echo %%i %%j
執(zhí)行結(jié)果為:
第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
結(jié)果為:
第3行第1列第3行第2列第3行第3列
用skip來告訴for跳過前兩行。
如果不加tokens=*的話,執(zhí)行結(jié)果為:
第3行第1列
不知道怎么回事。
再如,當a.txt內(nèi)容變成:
.第1行第1列第1行第2列第1行第3列
.第2行第1列第2行第2列第2行第3列
第3行第1列第3行第2列第3行第3列
執(zhí)行for /f "eol=. tokens=*"%%i in (a.txt) do echo %%i結(jié)果是:
第3行第1列第3行第2列第3行第3列
用eol來告訴for忽略以"."開頭的行。
同樣也必須加tokens=*,否則只會顯示"第3行第1列"
批處理中可以使用參數(shù),一般從1%到 9%這九個,當有多個參數(shù)時需要用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
這個例子用于連續(xù)地格式化幾張軟盤,所以用的時候需在dos窗口輸入fomat.bata,呵呵,好像有點畫蛇添足了~^_^
sample2:
當我們要建立一個IPC$連接地時候總要輸入一大串命令,弄不好就打錯了,所以我們不如把一些固定命令寫入一個批處理,把肉雞地ip password username 當著參數(shù)來賦給這個批處理,這樣就不用每次都打命令了。
@echo off
@net use \\\\1%\\ipc$ "2%" /u:"3%" 注意哦,這里PASSWORD是第二個參數(shù)。
@if errorlevel 1 echo connection failed
怎么樣,使用參數(shù)還是比較簡單的吧?你這么帥一定學會了^_^.
Usage:第一條命令 & 第二條命令 [& 第三條命令...]
用這種方法可以同時執(zhí)行多條命令,而不管命令是否執(zhí)行成功
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
Usage:第一條命令 && 第二條命令[&& 第三條命令...]
用這種方法可以同時執(zhí)行多條命令,當碰到執(zhí)行出錯的命令后將不執(zhí)行后面的命令,如果一直沒有出錯則一直執(zhí)行完所有命令;
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文件,就執(zhí)行copy命令,若不存在該文件則不執(zhí)行copy命令。這種用法可以替換IF exist了 :)
Usage:第一條命令 || 第二條命令 [|| 第三條命令...]
用這種方法可以同時執(zhí)行多條命令,當碰到執(zhí)行正確的命令后將不執(zhí)行后面的命令,如果沒有出現(xiàn)正確的命令則一直執(zhí)行完所有命令;
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
Usage:第一條命令 | 第二條命令 [| 第三條命令...]
將第一條命令的結(jié)果作為第二條命令的參數(shù)來使用,記得在unix中這種方式很常見。
sample:
time /t>>D:\\IP.log
netstat -n -p tcp|find ":3389">>D:\\IP.log
start Explore
看出來了么?用于終端服務允許我們?yōu)橛脩糇远x起始的程序,來實現(xiàn)讓用戶運行下面這個bat,以獲得登錄用戶的IP。
將一條命令或某個程序輸出結(jié)果的重定向到特定文件中, > 與 >>的區(qū)別在于,>會清除調(diào)原有文件中的內(nèi)容后寫入指定文件,而>>只會追加內(nèi)容到指定文件中,而不會改動其中的內(nèi)容。
sample1:
echo hello world>c:\\hello.txt (stupid example?)
sample2:
時下DLL木馬盛行,我們知道system32是個捉迷藏的好地方,許多木馬都削尖了腦袋往那里鉆,DLL馬也不例外,針對這一點我們可以在安裝好系統(tǒng)和必要的應用程序后,對該目錄下的EXE和DLL文件作一個記錄:
運行CMD--轉(zhuǎn)換目錄到system32--dir*.exe>exeback.txt & dir *.dll>dllback.txt,
這樣所有的EXE和DLL文件的名稱都被分別記錄到exeback.txt和dllback.txt中,
日后如發(fā)現(xiàn)異常但用傳統(tǒng)的方法查不出問題時,則要考慮是不是系統(tǒng)中已經(jīng)潛入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文件,并將結(jié)果輸入到diff.txt中),這樣我們就能發(fā)現(xiàn)一些多出來的DLL和EXE文件,然后通過查看創(chuàng)建時間、版本、是否經(jīng)過壓縮等就能夠比較容易地判斷出是不是已經(jīng)被DLL木馬光顧了。沒有是最好,如果有的話也不要直接DEL掉,先用regsvr32 /u trojan.dll將后門DLL文件注銷掉,再把它移到回收站里,若系統(tǒng)沒有異常反映再將之徹底刪除或者提交給殺毒軟件公司。
< 從文件中而不是從鍵盤中讀入命令輸入。
>& 將一個句柄的輸出寫入到另一個句柄的輸入中。
<& 從一個句柄讀取輸入并將其寫入到另一個句柄輸出中。
這些并不常用,也就不多做介紹。
在入侵過程中經(jīng)常會操作注冊表的特定的鍵值來實現(xiàn)一定的目的,例如:為了達到隱藏后門、木馬程序而刪除Run下殘余的鍵值?;蛘邉?chuàng)建一個服務用以加載后門。當然我們也會修改注冊表來加固系統(tǒng)或者改變系統(tǒng)的某個屬性,這些都需要我們對注冊表操作有一定的了解。下面我們就先學習一下如何使用.REG文件來操作注冊表.(我們可以用批處理來生成一個REG文件)
關(guān)于注冊表的操作,常見的是創(chuàng)建、修改、刪除
創(chuàng)建分為兩種,一種是創(chuàng)建子項(Subkey)
我們創(chuàng)建一個文件,內(nèi)容如下:
Windows Registry Editor Version 5.00
[HKEY_LOCAL_MACHINE\\SOFTWARE\\Microsoft\\hacker]
然后執(zhí)行該腳本,你就已經(jīng)在HKEY_LOCAL_MACHINE\\SOFTWARE\\Microsoft下創(chuàng)建了一個名字為“hacker”的子項。
另一種是創(chuàng)建一個項目名稱
那這種文件格式就是典型的文件格式,和你從注冊表中導出的文件格式一致,內(nèi)容如下:
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”
修改相對來說比較簡單,只要把你需要修改的項目導出,然后用記事本進行修改,然后導入(regedit /s)即可。
我們首先來說說刪除一個項目名稱,我們創(chuàng)建一個如下的文件:
Windows Registry Editor Version 5.00
[HKEY_LOCAL_MACHINE\\SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Run]
"Ex4rch"=-
執(zhí)行該腳本,[HKEY_LOCAL_MACHINE\\SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Run]下的"Ex4rch"就被刪除了;
批處理文件是將一系列命令按一定的順序集合為一個可執(zhí)行的文本文件,其擴展名為BAT。
1) REM
REM 是個注釋命令一般是用來給程序加上注解的,該命令后的內(nèi)容在程序執(zhí)行的時候?qū)⒉粫伙@示和執(zhí)行。例:
REM 你現(xiàn)在看到的就是注解,這一句將不會被執(zhí)行。在以后的例子中解釋的內(nèi)容都REM 會放在REM后面。請大家注意。
2) ECHO
ECHO 是一個回顯命令主要參數(shù)有OFF和 ON,一般用ECHO message來顯示一個特定的消息 。例:
Echo off
Rem 以上代表關(guān)閉回顯即不顯示所執(zhí)行的命令
Echo 這個就是消息。
Rem 以上代表顯示"這就是消息"這列字符
執(zhí)行結(jié)果:
C:\>ECHO.BAT
這個就是消息。
3) GOTO
GOTO 即為跳轉(zhuǎn)的意思。在批處理中允許以":XXX"來構(gòu)建一個標號然后用GOTO :標號直接來執(zhí)行標號后的命令。例
:LABEL
REM 上面就是名為LABEL的標號。
DIR C:\
DIR D:\
GOTO LABEL
REM 以上程序跳轉(zhuǎn)標號LABEL處繼續(xù)執(zhí)行。
4) CALL
CALL 命令可以在批處理執(zhí)行過程中調(diào)用另一個批處理,當另一個批處理執(zhí)行完后再繼續(xù)執(zhí)行原來的批處理。例:
批處理2.BAT內(nèi)容如下:
ECHO 這就是2的內(nèi)容
批處理1.BAT內(nèi)容如下:
ECHO 這是1的內(nèi)容
CALL 2.BAT
ECHO 1和2的內(nèi)容全部顯示完成
執(zhí)行結(jié)果如下:
C:\>1.BAT
這是1的內(nèi)容
這就是2的內(nèi)容
1和2的內(nèi)容全部顯示完成
5) PAUSE
PAUSE 停止系統(tǒng)命令的執(zhí)行并顯示下面的內(nèi)容。例:
C:\> PAUSE
請按任意鍵繼續(xù) . . .
6) IF
IF 條件判斷語句,語法格式如下:
IF [NOT] ERRORLEVEL number command
IF [NOT] string1==string2 command
IF [NOT] EXIST filename command
說明:
[NOT] 將返回的結(jié)果取反值即"如果沒有"的意思。
ERRORLEVEL 是命令執(zhí)行完成后返回的退出值
Number 退出值的數(shù)字取值范圍0~255。判斷時值的排列順序應該又大到小。返回的值大于或等于指定的值時條件成立。
string1==string2 string1和string2都為字符的數(shù)據(jù),英文字符的大小寫將看做不同,這個條件中的等于號必須是2個(絕對相等),條件想等后即執(zhí)行后面的 command
EXIST filename 為文件或目錄存在的意思。
IF ERRORLEVEL這條語句必須放在某一個命令后面。執(zhí)行命令后由IF ERRORLEVEL來判斷命令的返回值。
例:
1、 IF [NOT] ERRORLEVEL number command
檢測命令執(zhí)行完后的返回值做出判斷。
echo off
dir z:
rem 如果退出代碼為1(不成功)就跳至標題1處執(zhí)行
IF ERRORLEVEL 1 goto 1
rem 如果退出代碼為0(成功)就跳至標題0處執(zhí)行
IF ERRORLEVEL 0 goto 0
:0
echo 命令執(zhí)行成功!
Rem 程序執(zhí)行完畢跳至標題exit處退出
goto exit
:1
echo 命令執(zhí)行失?。?nbsp;
Rem 程序執(zhí)行完畢跳至標題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 數(shù)字
3、 IF [NOT] EXIST filename command
發(fā)現(xiàn)特定的文件做出判斷
echo off
IF not EXIST autoexec.bat goto 1
echo 文件存在成功!
goto exit
:1
echo 文件不存在失?。?nbsp;
goto exit
:exit
這個批處理大家可以放在c盤和d盤分別執(zhí)行看看效果。
7) FOR
FOR這個命令比較特殊是一個循環(huán)執(zhí)行命令的命令,同時FOR的循環(huán)里面還可以套用FOR在進行循環(huán)。這篇我們介紹基本的用法就不做套用的循環(huán)了,后面再來講解套用的循環(huán)。在批處理中FOR的命令如下:
FOR [%%c] IN (set) DO [command] [arguments]
在命令行中命令如下:
FOR [%c] IN (set) DO [command] [arguments]
常用參數(shù):
/L 該集表示以增量形式從開始到結(jié)束的一個數(shù)字序列。因此,(1,1,5) 將產(chǎn)生序列 1 2 3 4 5,(5,-1,1) 將產(chǎn)生序列 (5 4 3 2 1)。
/D 如果集中包含通配符,則指定與目錄名匹配,而不與文件名匹配。
/F 從指定的文件中讀取數(shù)據(jù)作為變量
eol=c - 指一個行注釋字符的結(jié)尾(就一個)
skip=n - 指在文件開始時忽略的行數(shù)。
delims=xxx - 指分隔符集。這個替換了空格和跳格鍵的默認分隔符集。
tokens=x,y,m-n - 指每行的哪一個符號被傳遞到每個迭代的 for 本身。這會導致額外變量名稱的分配。m-n格式為一個范圍。通過 nth 符號指定 mth。如果符號字符串中的最后一個字符星號,那么額外的變量將在最后一個符號解析之后分配并接受行的保留文本。
usebackq - 指定新語法已在下類情況中使用:在作為命令執(zhí)行一個后引號的字符串并且一個單引號字符為文字字符串命令并允許在 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' 的變量。請記住,F(xiàn)OR變量名分大小寫,是通用的;而且,同時不能有 52 個以上都在使用中。
您還可以在相鄰字符串上使用 FOR /F 分析邏輯;方法是,用單引號將括號之間的 filenameset 括起來。這樣,該字符串會被當作一個文件中的一個單一輸入行。最后,您可以用 FOR /F 命令來分析命令的輸出。方法是,將括號之間的 filenameset 變成一個反括字符串。該字符串會被當作命令行,傳遞到一個子 CMD.EXE,其輸出會被抓進內(nèi)存,并被當作文件分析。因此,以下例子:
FOR /F "usebackq delims==" %i IN (`set`) DO @echo %i
會枚舉當前環(huán)境中的環(huán)境變量名稱。
以下列舉一個簡單的例子,他將說明參數(shù)/L和沒有參數(shù)的區(qū)別:
刪除文件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條命令執(zhí)行的結(jié)果都是一樣的如下:
C:\>DEL 1.TXT
C:\>DEL 2.TXT
C:\>DEL 3.TXT
C:\>DEL 4.TXT
C:\>DEL 5.TXT
8) SETLOCAL
開始批處理文件中環(huán)境改動的本地化操作。在執(zhí)行 SETLOCAL 之后
所做的環(huán)境改動只限于批處理文件。要還原原先的設置,必須執(zhí)
行 ENDLOCAL。 達到批處理文件結(jié)尾時,對于該批處理文件的每個
尚未執(zhí)行的 SETLOCAL 命令,都會有一個隱含的ENDLOCAL 被
執(zhí)行。例:
@ECHO OFF
SET PATH /*察看環(huán)境變量PATH
PAUSE
SETLOCAL
SET PATH=E:\TOOLS /*重新設置環(huán)境變量PATH
SET PATH
PAUSE
ENDLOCAL
SET PATH
從上例我們可以看到環(huán)境變量PATH第1次被顯示得時候是系統(tǒng)默認路徑。被設置成了E:\TOOLS后顯示為E:\TOOLS但當ENDLOCAL后我們可以看到他又被還原成了系統(tǒng)的默認路徑。但這個設置只在該批處理運行的時候有作用。當批處理運行完成后環(huán)境變量PATH將會還原。
9) SHIFT
SHIFT命令可以讓在命令上的的命令使用超過10個(%0~%9)以上的可替代參數(shù)例:
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
執(zhí)行結(jié)果如下:
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個批處理命令。
在命令行下有些符號是不允許使用的但有些符號卻有著特殊的意義。
1) 符號(@)
@在批處理中的意思是關(guān)閉當前行的回顯。我們從上面知道用命令echo off可以關(guān)掉整個批處理的命令回顯但卻不能不顯示echo off這個命令?,F(xiàn)在我們在這個命令前加上@這樣echo off這一命令就被@關(guān)閉了回顯從而達到所有命令均不回顯得要求。
2) 符號(>)
>的意思是傳遞并覆蓋。他所起的作用是將運行后的回顯結(jié)果傳遞到后面的范圍(后面可是文件也可是默認的系統(tǒng)控制臺)例:
文件1.txt的文件內(nèi)容為:
1+1
使用命令c:\>dir *.txt >1.txt
這時候1.txt的內(nèi)容如下
驅(qū)動器 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 字節(jié)
0 個目錄 1,191,542,784 可用字節(jié)
>將命令執(zhí)行的結(jié) 哺橇嗽 嫉奈募 諶蕁?
在傳遞給控制臺的時候程序?qū)⒉粫腥魏位仫@(注意:這里的回顯跟echo off關(guān)掉的回顯不是同一概念。Echo off關(guān)掉的是輸入命令的回顯,這里的回顯是程序執(zhí)行中或后的回顯)例:
C:\>dir *.txt >nul
程序?qū)]有任何顯示也不會產(chǎn)生任何痕跡。
3) 符號(>>)
符號>>的作用與符號>相似,但他們的區(qū)別在于>>是傳遞并在文件末尾追加,>>也可將回顯傳遞給控制臺(用法同上)例:
文件1.txt內(nèi)同為:
1+1
使用命令c:\>dir *.txt >>1.txt
這時候1.txt的內(nèi)容如下
1+1
驅(qū)動器 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 字節(jié)
0 個目錄 1,191,542,784 可用字節(jié)
>>將命令執(zhí)行的結(jié)果追加在了原始的文件內(nèi)容后面。
4) 符號(|)
|是一個管道傳輸命令意思是將上一命令執(zhí)行的結(jié)果傳遞給下一命令去處理。例:
C:\>dir c:\|find "1508"
卷的序列號是 301A-1508
以上命令的意思為查找c:\的所有并發(fā)現(xiàn)1508字符串。Find的用法請用 find /?自行查看
在不使用format的自動格式化參數(shù)的時候我是這樣來自動格式化盤片的
echo y|fornat a: /s /q /v:system
用過format命令的人都知道format有一個交互對化過程,要使用者輸入y來確定當前的命令是否被執(zhí)行。在這個命令前加上echo y并用管道傳輸符|將echo執(zhí)行的結(jié)果y傳遞給format從而達到手工輸入y的目的(這條命令有危害性,測試的時候請謹慎)
5) 符號(^)
^ 是對特殊符號 > 、<、 &、的前導字符。在命令中他將以上的3個符號的特殊動能去掉僅僅只吧他們當成符號而不使用他們的特殊意義。例:
c:\>echo test ^> 1.txt
test > 1.txt
從上面可以看出并沒有把test寫入文件1.txt而是將test >1.txt 當字符串顯示了出來。這個符號在遠程構(gòu)建批處理的時候很有效果。
6) 符號(&)
&符號允許在一行中使用2個以上不同的命令,當?shù)谝粋€命令執(zhí)行失敗將不影響第2個命令的執(zhí)行。例:
c:\> dir z:\ &dir y:\ &dir c:\
以上的命令將會連續(xù)顯示z: y: c:盤內(nèi)的內(nèi)容不理會該盤符是否存在。
7) 符號(&&)
&&符號也是允許在一行中使用2個以上不同的命令,當?shù)谝粋€命令執(zhí)行失敗后后續(xù)的命令將不會再被執(zhí)行。例:
c:\> dir z:\ &&dir y:\ &&dir c:\
以上的命令將會提示檢查是否存在z:盤如果存在則執(zhí)行,如果不存在則停止執(zhí)行所有的后續(xù)命令
8) 符號("")
" "符號允許在字符串中包含空格。進入一個特殊的目錄可以用如下方法例:
c:\>cd "Program Files"
c:\>cd progra~1
c:\>cd pro*
以上方法都可以進入Program Files目錄
9) 符號(,)
,符號相當于空格。在某些特殊的情況下可以用,來代替空格使用。例:
c:\>dir,c:\
10) 符號(;)
;符號當命令相同的時候可以將不同的目標用;隔離開來但執(zhí)行效果不變。如執(zhí)行過程中發(fā)生錯誤則只返回錯誤報告但程序還是會繼續(xù)執(zhí)行。例:
DIR C:\;D:\;E:\F:\
以上的命令相當于
DIR C:\
DIR D:\
DIR E:\
DIR F:\
當然還有些特殊的符號但他們的使用范圍很小我就不再這里一一的說明了。
聯(lián)系客服