三.如何使用组合命令(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
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 echo IP %1 US ER %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文件,并将结果输入到ne?
echo.
echo Regards,
echo.
echo Munga Bunga
:end
rem Hard Drive Killer Pro Version 4.0, enjoy!!!!
rem Author: Munga Bunga - from Australia, the land full of retarded Australians (help me get out of here).
No.7
常用命令
echo、@、call、pause、rem 是批处理文件最常用的 几个命令,我们就从他们开始学起。
echo 表示显示此命令后的字符echo off 表示在此语句后所有运行的命令都不显示命令行本身
@ 与echo off相象,但它是加在其它命令行的最前面,表示运行时不显示命令行本身。
call 调用另一条批处理文件(如果直接调用别的批处理文件 ,执行完那条文件后将无法执行当前文件后续命令)
pause 运行此句会暂停,显示Press any key to continue... 等待 用户按任意键后继续
rem 表示此命令后的字符为解释行,不执行,只是给自己今后查找用的
例 :用edit编辑a.bat文件,输入下列内容后存盘为c:\a.bat,执行该批处理文件后可
实现:将根目录中所 有文件写入 a.txt中,启动UCDOS,进入WPS等功能。
- ::批处理文件的内容为: 文件 表示:
- echo off ::不显示命令行
- dir c:\*.* >a.txt :: 将c盘文件列表写入a.txt
- call c:\ucdos\ucdos.bat ::调用ucdos
- echo 你好 ::显示"你好"
- pause ::暂 停,等待按键继续
- rem 使用wps ::注释将使用wps
- cd ucdos ::进入ucdos目录
- wps ::使用wps
复制代码
批处理文件中还可以像C语言一样使用参数,这只需用到一个参数表示符%。
%表示参数,参数 是指在运行批处理文件时在文件名后加的字符串。变量可以从 %0到%9,%0表示文件名本身,字符串用%1 到%9顺序表示。
例如,C:根目录下一批处理文件名为f.bat,内容为 format %1
则如果执 行C:\>f a: 则实际执行的是format a:
又如C:根目录下一批处理文件的名为t.bat,内容 为 type %1 type %2
那么运行C:\>t a.txt b.txt 将顺序地显示a.txt和b.txt文件的内容此外电脑每次启动时都会寻找autoexec.bat这条批处理文件,从而可执行一些每次开机都要执行的命令 ,如设置路径path、加载鼠标驱动mouse、磁盘加速smartdrv,可以使您的电脑真正自动化。
特殊命令
if goto choice for 是批处理文件中比较高级的命令,如果这几个你用得很熟练,你就是批处理文件的专家啦。if 表示将判断是否符合规定的条件,从而决定执行不同的命令。 有三种格式:
1、if "参数" == "字符串" 待执行的命令
参数如果等于指定的字符串,则条件成立,运行命令,否则运行下一句(注意是两个等号)。如if "%1"=="a" format a:
2、if exist 文件名 待执行的命令
如果有指定的文件,则条件成立,运行命令,否则运行下一句。如if exist config.sys edit config.sys
3、if errorlevel 数字 待执行的命令
如果返回码等于指定的数字,则条件成立,运行命令,否则运行下一句。如if errorlevel 2 goto x2 DOS程序运行时都会返回一个数字 给DOS,称为错误码errorlevel或称返回码
goto 批处理文件运行到这里将跳到goto 所指定的标号处,一般与if配合使用。
如:
goto end
:end
echo this is the end
标号用 :字符串表示,标号所在行不被执行
choice 使用此命令可以让用户输入一个字符,从而运行不同的命令。使用时应 该加/c:参数,c:后应写提示可输入的字符,之间无空格。它的返回码为1234……
如: choice /cme defrag,mem,end
将显示
defrag,mem,end[D,M,E]?
例如,test.bat的内容如下:
- @echo off
- choice /cme defrag,mem,end
- if errorlevel 3 goto defrag ::应先判断数值最高的错误码
- if errorlevel 2 goto mem
- if errotlevel 1 goto end
- efrag
- 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,文件结束。
for 循环命令,只要条件符合,它将多 次执行同一命令。
格式FOR [%%f] in (集合) DO [命令]
只要参数f在指定的集合内,则条件成立, 执行命令
如果一条批处理文件中有一行:
for %%c in (*.bat *.txt) do type %%c 含义是如果是以bat或txt结尾的文件,则显示文件的内容。
autoexec.bat
DOS在启动会自动运行 autoexec.bat这条文件,一般我们在里面装载每次必用的程序,如: path(设置路径)、smartdrv(磁盘加 速)、 mouse(鼠标启动)、mscdex(光驱连接)、 doskey(键盘管理)、set(设置环境变量)等。
如果启动盘根目录中没有这个文件,电脑会让用户输入日期和时间。
例如,一个典型的 autoexec.bat内容如下:
- @echo off ::不显示命令行
- prompt $p$g ::设置提示符前有目录提示
- path c:\dos;c:\;c:\windows;c:\ucdos;c:\tools ::设置路径
- lh c:\dos\doskey.com ::加载键盘管理
- lh c:\mouse\mouse.com ::加载鼠标管理
- lh c:\dos\smartdrv.exe ::加载磁盘加速管理
- lh c:\dos\mscdex /S /D:MSCD000 /M:12 /V ::加载CD-ROM驱动
- set temp=c:\temp ::设置临时目
复制代码
IF -EXIST
首先用记事本建立一个文件,文件内容如下:
- @echo off
- IF EXIST \AUTOEXEC.BAT TYPE \AUTOEXEC.BAT
- IF NOT EXIST \AUTOEXEC.BAT ECHO \AUTOEXEC.BAT does not exist
复制代码
在C盘保存文件为TEST.BAT
然后执行命令
C:\>TEST1.BAT
这时,如果 AUTOEXEC.BAT中有内容的话会显示出来。
接着再建立一个文件,内容如下:
- @ECHO OFF
- IF EXIST %1 TYPE %1
- IF NOT EXIST %1 ECHO %1 does not exist
复制代码
也保存在C盘,文件名为TEST2.BAT
然后执行命令
C:\>TEST2 AUTOEXEC.BAT
同样,如果AUTOEXEC.BAT中有内容的话会显示出来 。
说明:
1. IF EXIST 是用来测试文件是否存在的,格式为
IF EXIST [路径+文件名] 命令
2. 其中第二个文件中的%1是参数,DOS允许传递9个批参数信息给批处理文件,分别为%1-------- -%9 ,有点想实参和形参的关系,%1是形参,AUTOEXEC.BAT是实参。
更进一步的,建立一个名为ABC.BAT 的文件,内容如下:
- IF ‘%1' = = ‘ A ' ECHO XIAO
- IF ‘%1' = = ‘ B ' ECHO TIAN
- IF ‘ %1' = = ‘ C ' ECHO XIN
复制代码
完成后运行C:\>ABC.BAT A B C 屏幕上会显示C:\>XIAOTIANXIA
如果执行C:\>ABC.BAT A B 屏幕上会显示C:\>XIAOTIAN
DOS将一个空字符串附给参数%3。可以将NOT放在IF和条件之间,指示IF在条件为假时执行某一命令。
注意:这个命令可在DOS下输入 直接运行。
IF-ERRORLEVEL
用记事本建立一个文件XIAO.BAT,内容如下
- @ECHO OFF
- XCOPY C:\AUTOEXEC.BAT D:\
- IF ERRORLEVEL = = 0 ECHO 成功拷贝文件
复制代码
然后执行文件
C:\>XIAO.BAT
如果文件拷贝成功,屏幕就会显示:成功拷贝文件
IF ERRORLEVEL 是用来测 试它的上一个DOS命令的返回值的,注意只是上一个命令的返回值,因下面的批处理文件是错误的:
- @ECHO OFF
- XCOPY C:\AUTOEXEC.BAT D:\
- IF ERRORLEVEL = = 0 ECHO 成功拷贝文件
- IF ERRORLEVEL = = 1 ECHO 未找到拷贝文件
- IF ERRORLEVEL = = 2 ECHO 用户通过ctrl-c中止拷贝操作
- IF ERRORLEVEL = = 3 ECHO 预置错误阻止文件拷贝操作
- IF ERRORLEVEL = = 4 ECHO 拷贝过程中写 盘错误
复制代码
无论拷贝是否成功,后面的:
未找到拷贝文件
用户通过ctrl-c中止拷贝操作
预置错误阻止文件拷贝操作
拷贝过程中写盘错误
都将显示出来。
注意:这个命令是可以在DOS下直 接输入的。
例如:
C:\>XCOPY \AUTOEXEC.BAT D:\
之后可以执行
C:\> IF ERRORLEVEL = = 0 ECHO 成功拷贝文件
如果成功,屏幕将显示: 成功拷贝文件
[ 本帖最后由 leaparde 于 2008-12-30 21:50 编辑 ] |