1 概述
1.1 课程设计目的
加深TCP/IP协议的理解,掌握TCP四次握手机制,同时熟悉socket编程。
1.2 课程设计内容
实现一个端口扫描器:
支持多进程/线程
能对单个指定主机进行扫描或扫描指定网段内的主机
能扫描特定的部分端口或对指定的端口段内的端口进行逐个扫描
能够显示所开放端口的服务名称
1.3 运行环境
操作系统:Windows 7及以上版本系统
开发环境:Microsoft Visual Studio 2013
2 系统分析与设计
2.1 原理概述
端口扫描有好几种,但其中TCP connect扫描是最基本的扫描,我们可以利用系统提供的connect()用来与每一个目标计算机的端口进行连接。如果端口处于侦听状态,那connect()就能成功。否则,这个端口即是不可用的,也就是说没有提供服务。这个技术的一个最大的优点是,你不需要任何权限。系统中的任何用户都有权利使用这个调用。另一个好处就是速度,如果对每个目标端口以线性的方式,使用单独的connect()调用,那么将花费相当长的时间,使用者可以通过多线程同时打开多个套接字来加速扫描。使用非阻塞I/O允许设置一个低的时间用尽周期,同时观察多个套接字。但这种方法的缺点是很容易被察觉,并且被防火墙将扫描信息包过滤掉。目标计算机的Logs文件会显示一连串的连接和连接出错消息,并且能很快使它关闭。
参考文档和完整的文档和源码下载地址: