Kali学习笔记9:端口扫描详解(上)
UDP端口扫描:
原理:回应ICMP不可达,代表端口关闭;没有回应,端口开启
建议了解应用层的UDP包头结构,构建对应的UDP数据包用来提高准确度
另外:所有的扫描都存在误判情况
我们用Scapy写个脚本来试试:
#!/usr/bin/python
import logging logging.getLogger("scapy.runtime").setLevel(logging.ERROR)
from scapy.all import *
import time
import sys if len(sys.argv) != 4:
print "./udp_scan.py [target ip] [first port] [last port]"
print "example ./udp_scan.py 10.0.0.5 1 100"
print "example will UDP port scan ports 1 to 100 on 10.0.0.5" ip = sys.argv[1]
start = int(sys.argv[2])
end = int(sys.argv[3]) for port in range(start, end):
a = sr1(IP(dst=ip) / UDP(dport=port), timeout=5, verbose=0)
time.sleep(1)
if a == None:
print port
else:
pass
如果是从WINDOWS复制过去的
vi udp_scan.py
:set fileformat=unix
:wq
chmod u+x udp_scan.py
执行:./udp_scan.py 10.0.0.0 1 100
接下来看看使用最强大的Nmap:
Nmap在端口扫描方面使用-sU参数
而我们使用Nmap如果不指定任何端口的话,他会扫描定义好的1000个常用端口

当然也可以指定端口扫描:

如果你一定要扫描全部端口,也是可以的:

好的,接下来我们看TCP端口扫描:
基于连接协议扫描:
所有的扫描都是基于三次握手的变化来判断目标端口状态
首先我们先用SCAPY演示:
我开启一个Metasploitable的虚拟机,查看到它的IP:192.168.22.129
再查看下Kali虚拟机的IP:192.168.22.130
打开Scapy测试:
我们主动发一个SYN包,只要回应SYN+ACK包,就代表端口开启,
我们不能继续回应ACK包,而要回复RST断开连接防止被发现!

第一行的意思是发送一个TCP数据包将返回值赋给a
然后我们查看下这个a包:发现默认扫描80端口,并且返回SYN+ACK
我们为什么这里不主动回RST包呢?
原因:可以抓包发现,操作系统会自动回复给"莫名其妙"的TCP包RST
接下来我们换个端口扫描:22

这种情况也说明这里的22端口是开放的
那么如果我们扫描一个关闭的端口呢?

发现目标机器回复的是一个RST+ACK
代表:这台机器是活着的,但是当前扫描的端口(22222)是没有开放的
我们在scapy的基础上写一个简单的扫描脚本:syn_scan.py
#!/usr/bin/python
import logging logging.getLogger("scapy.runtime").setLevel(logging.ERROR)
from scapy.all import *
import time
import sys if len(sys.argv) != 4:
print "./syn_scan.py [target ip] [first port] [last port]"
print "example ./udp_scan.py 10.0.0.5 1 100"
print "example will TCP SYN scan ports 1 to 100 on 10.0.0.5" ip = sys.argv[1]
start = int(sys.argv[2])
end = int(sys.argv[3]) for port in range(start, end):
a = sr1(IP(dst=ip) / TCP(dport=port), timeout=1, verbose=0)
time.sleep(1)
if a == None:
pass
else:
if int(a[TCP].flags)==18:
print port
else:
pass
难点:这里为什么flags==18?
抓包发现SYN和ACK分别是2和2的4次方即为16,加在一起恰好为18
使用这个脚本:
老规矩,如果是windows转移过去的:
vi syn_scan.py
:set fileformat=unix
:wq
chmod u+x syn_scan.py
执行:./syn_scan.py 10.0.0.0 1 100

这里并没有扫描完全,不过效果达到了(如果扫windows端口,1-100不会有任何开放端口)
隐蔽端口扫描这种方式其实比UDP的方式稳多了
当然,强大的Nmap也可以实现:而且效率更高
不过扫描原理就是上边写的内容
无参数扫描:

使用后发现比自己搞的脚本快太多,而且完善,真不愧是强大的Nmap
这里我们扫描的机器没有防火墙,所以扫描到的端口都是open的,如果存在close或filter,我们需要一个参数才能获取open的端口

nmap还可以加上一个参数:-sS:

其实和默认方式是一样的,所以直接使用即可
如果需要全部扫描:nmap [ip] -p -65535
如果需要扫描指定端口:nmap [ip] -p 80,22,...,139
其他端口扫描方式:
Hping3:

-S表示用SYN扫描,flags的S,A当然就代表SYN和ACK了
下面来个有趣的:

先解释下这行命令:-c 100发送一百个包,和-p ++1组合,意味对端口1-100分别发送SYN包,
有趣在--spoof参数,伪造源IP地址,我这台机器无法查看扫描结果,只有我登陆伪造的192.168.168.168机器才可以查看结果。
其实下边这十几行都没有用
这种方式有很大的优点也有很大的缺点:
优点:非常隐蔽,基本不会被发现,在目标看来是另外一个机器发送的探测数据包
缺点:麻烦,需要另外一台机器
上边的都是TCP半连接端口扫描
接下来,看看TCP全连接端口扫描:
下一篇博客我们继续:
Kali学习笔记9:端口扫描详解(上)的更多相关文章
- IP2——IP地址和子网划分学习笔记之《子网掩码详解》
2018-05-04 16:21:21 在学习掌握了前面的<进制计数><IP地址详解>这两部分知识后,要学习子网划分,首先就要必须知道子网掩码,只有掌握了子网掩码这部分内容 ...
- Kali学习笔记10:端口扫描详解(下)
上一篇先是介绍了UDP的端口扫描,又谈了TCP的不完全连接端口扫描 https://www.cnblogs.com/xuyiqing/p/9389276.html 接下来我们看看TCP的全连接端口扫描 ...
- CDN学习笔记二(技术详解)
一本好的入门书是带你进入陌生领域的明灯,<CDN技术详解>绝对是带你进入CDN行业的那盏最亮的明灯.因此,虽然只是纯粹的重点抄录,我也要把<CDN技术详解>的精华放上网.公诸同 ...
- [读书笔记]C#学习笔记三: C#类型详解..
前言 这次分享的主要内容有五个, 分别是值类型和引用类型, 装箱与拆箱,常量与变量,运算符重载,static字段和static构造函数. 后期的分享会针对于C#2.0 3.0 4.0 等新特性进行. ...
- C#学习笔记二: C#类型详解
前言 这次分享的主要内容有五个, 分别是值类型和引用类型, 装箱与拆箱,常量与变量,运算符重载,static字段和static构造函数. 后期的分享会针对于C#2.0 3.0 4.0 等新特性进行. ...
- 【Java学习笔记之三十三】详解Java中try,catch,finally的用法及分析
这一篇我们将会介绍java中try,catch,finally的用法 以下先给出try,catch用法: try { //需要被检测的异常代码 } catch(Exception e) { //异常处 ...
- jQuery学习笔记之Ajax用法详解
这篇文章主要介绍了jQuery学习笔记之Ajax用法,结合实例形式较为详细的分析总结了jQuery中ajax的相关使用技巧,包括ajax请求.载入.处理.传递等,需要的朋友可以参考下 本文实例讲述了j ...
- MyBatis学习笔记2--配置环境详解
1.MyBatis-config.xml详解 一个完整的配置文件如下所示 <configuration> <!-- <properties resource="jdb ...
- [Spring学习笔记 5 ] Spring AOP 详解1
知识点回顾:一.IOC容器---DI依赖注入:setter注入(属性注入)/构造子注入/字段注入(注解 )/接口注入 out Spring IOC容器的使用: A.完全使用XML文件来配置容器所要管理 ...
随机推荐
- 如何监听Element组件<el-input>标签的回车事件
一.现象 表单提交时需要处理输入框的回车事件,一般的原生input标签可以用@keyup.enter="onSubmit"(tips:onSubmit为定义的方法) 二.解决 1. ...
- Lonsdor K518ISE programs 2005 Ford Focus key in two minutes
A quick demonstration of Lonsdor K518ISE programming key for 2005 Ford Focus in two minutes. And for ...
- win10无法访问服务器上的共享文件夹怎么设置,提示:你不能访问此共享文件夹,因为你组织的安全策略阻止未经身份验证的来宾访问
此问题需要修改Win10 网络策略 按window+R键输入gpedit.msc 来启动本地组策略编辑器. 依次找到“计算机配置-管理模板-网络-Lanman工作站”这个节点,在右侧内容区可以看到“启 ...
- python基础之Day18
一.序列化概念 什么是序列化? 内存中的数据结构转成中间格式(json(所有编程语言通用)和pickle)存储到硬盘或基于网络状态 反序列化: 硬盘网络传来的数据格式转换成内存的数据结构 为什么 1. ...
- sql语句性能优化
需要的准备知识 1最左前缀匹配 mysql会一直向右匹配直到遇到范围查询(>.<.between.like)就停止匹配, 对于where条件 a = 1 and b> 2 and c ...
- svn2个小问题的解决
Revision file (r615) lacks trailing newline /svndata/your_project/db/revs /svndata/your_project/db/r ...
- AX_Unit
UnitConvert::qty(_deliverNow, salesLine.SalesUnit, salesLine.inventTable().inventUnitId(), ...
- -1.记libgdx初次接触
学习一门技术最难的是开发环境变量配置和工具配置,以下为我初次接触libgdx时遇到的问题 几个难点记录下 gradle 直接用下到本地,然后放到d盘,链接到就行(gradle-wrapper.prop ...
- Docker优势以及与传统虚拟机对比(1)
docker优势 1.更快速地交付和部署: 2.更高的虚拟化(不需要额外的hypervisor支持,是内核级的虚拟化,实现更高的性能呢和效率): 3.更轻松的迁移和扩展: 4.更简单的管理 与传统的 ...
- 收集几个html和element-ui的录入控件
我希望有一个控件去显示或输入账本的金额 先做一些资料收集,也希望大家给个建议 输入银行账号会设置每四位添加一个空格 https://blog.csdn.net/wkx18330698534/artic ...