BAT程式設計命令詳解

2021-08-08 17:15:36 字數 6207 閱讀 7992

本文為cmd,bat下的程式語言流程,希望各位能用的上

如果沒有一定的相關知識恐怕不容易看懂和理解批處理檔案,也就更談不上自己動手編寫了

批處理檔案是無格式的文字檔案,它包含一條或多條命令。它的擴充套件名為 .bat 或 .

cmd。在命令提示下鍵入批處理檔案的名稱,或者雙擊該批處理檔案,系統就會呼叫cmd.exe按照該檔案中各個命令出現的順序來逐個執行它們。

使用批處理檔案(也被稱為批處理程式或指令碼),可以簡化日常或重複性任務。當然我們的這個版本的主要內容是介紹批處理在入侵中一些實際運用,例如我們後面要提到的用批處理檔案來給系統打補丁、批量植入後門程式等。下面就開始我們批處理學習之旅吧。

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

1.echo 命令

開啟回顯或關閉請求回顯功能,或顯示訊息。如果沒有任何引數,echo 命令將顯示當前回顯設定。

語法echo [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 == goto noparms

if == 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

memgoto 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 == goto noparms

if == 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 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-

檢查以 [drive:]path 為根的目錄樹,指向每個目錄中的

for 語句。如果在 /r 後沒有指定目錄,則使用當前

目錄。如果集僅為乙個單點(.)字元,則列舉該目錄樹。

for /l %variable in (start,step,end) do command [command-para

該集表示以增量形式從開始到結束的乙個數字序列。

因此,(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=*** - 指分隔符集。這個替換了空格和跳格鍵的

預設分隔符集。

tokens=x,y,m-n - 指每行的哪乙個符號被傳遞到每個迭代

的 for 本身。這會導致額外變數名稱的

格式為乙個範圍。通過 nth 符號指定 m

符號字串中的最後乙個字元星號,

那麼額外的變數將在最後乙個符號解析之

分配並接受行的保留文字。

usebackq - 指定新語法已在下類情況中使用:

在作為命令執行乙個後引號的字串並且

引號字元為文字字串命令並允許在 fi

中使用雙引號擴起檔名稱。

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 括起來。這樣,該字元

串會被當作乙個檔案中的乙個單一輸入行。

BAT中if命令詳解

if,正如它e文中的意思,就是 如果 的意思,用來進行條件判斷。翻譯過來的意思就是 如果符合某一條件,便執行後面的命令。if 命令示例詳解 if,正如它e文中的意思,就是 如果 的意思,用來進行條件判斷。翻譯過來的意思就是 如果符合某一條件,便執行後面的命令。主要用來判斷,1 兩個 字串 是否相等 ...

批處理bat程式設計詳解

批處理語法,bat語法 批處理就是把一批或者說是一條條命令放在乙個文字裡,然後批量執行 執行這 一批命令的檔案的副檔名是bat檔案或者cmd,把任何一批命令放入在有這樣副檔名的檔案裡,執行時裡面的命令就會一條條的執行完,當然 我們還可以在其中加入一些邏輯判斷的語句,讓裡面的命令在滿足一定條件時執行指...

BAT命令大全

關閉單行回顯 echo off從下一行開始關閉回顯 echo off 從本行開始關閉回顯。一般批處理第一行都是這個 echo on 從下一行開始開啟回顯 echo顯示當前是 echo off 狀態還是 echo on 狀態 echo輸出乙個 回車換行 空白行 同echo,echo echo echo...