package = IP(dst=ip)/TCP(sport=12345,dport=int(dport),flags="S") #flags=s代表发送syn请求 resp = sr1(package,timeout=20) if(str(type(resp))=="<type 'NoneType'>"): #这里需要判断回复给我们的信息,如果为空我们则判断关闭 print((dport)%"端口%s关闭") elif(resp.haslayer(TCP)): #我这里收到回复就需要判断一下回复的内容 if(resp.getlayer(TCP).flags==0x12): #这里我们判断flags信息头是0x12我们则判断确实返回给我们syn+ack,那我们就需要回一个ack包过去 send_rst = sr(IP(dst=ip)/TCP(sport=12345,dport=int(dport),flags="AR"),timeout=20) #所以这里我们发送第三次握手ack包 print("port %s is open"%(dport)) elif(resp.getlayer(TCP).flags==0x14): #返回0x14证明对方不想理我们 print("port %s is close"%(dport)) pass
if name == '__main__': main()
这里所有的含义我都会标注在代码下方,大家可以参考
**半开放扫描**
from whois import whois from scapy.all import * from random import * import time
def main(): ip = input("ip:") dport = input("端口号:")
package = IP(dst=ip)/TCP(sport=12345,dport=int(dport),flags="S")#flags=s代表发送syn请求 resp = sr1(package,timeout=20) if(str(type(resp))=="<type 'NoneType'>"): #这里需要判断回复给我们的信息,如果为空我们则判断关闭 print((dport)%"端口%s关闭") elif(resp.haslayer(TCP)): #我这里收到回复就需要判断一下回复的内容 if(resp.getlayer(TCP).flags==0x12): #这里我们判断flags信息头是0x12我们则判断确实返回给我们syn+ack,那我们就需要回一个ack包过去 send_rst = sr(IP(dst=ip)/TCP(sport=12345,dport=int(dport),flags="R"),timeout=20) print("port %s is open"%(dport)) elif(resp.getlayer(TCP).flags==0x14): #返回0x14证明对方不想理我们 print("port %s is close"%(dport))
pass
if name == '__main__': main()
代码并不多,去掉选择库和一些固定格式,也就是十二三行
区别就是判断完之后我们不发一个ack过去了,flags改为R发送过去就好了
总结来说步骤如下
1、第一步我们需要发送一个syn的请求包
2、第二步我们需要判断返回的数据包是否是空信息,是则判断关闭,不是则继续下一步
3、第三步判断我们收到的flags信息头是不是0x12,是的话我们就返回一个ack包,不是的话判断关闭,半开放扫描就不返回一个ack过去了
感兴趣的小伙伴,赠送全套Python学习资料,包含面试题、简历资料等具体看下方。

**一、Python所有方向的学习路线**
Python所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照下面的知识点去找对应的学习资源,保证自己学得较为全面。


**二、Python必备开发工具**
工具都帮大家整理好了,安装就可直接上手!
**三、最新Python学习笔记**
当我学到一定基础,有自己的理解能力的时候,会去阅读一些前辈整理的书籍或者手写的笔记资料,这些笔记详细记载了他们对一些技术点的理解,这些理解是比较独到,可以学到不一样的思路。

**四、Python视频合集**
观看全面零基础学习视频,看视频学习是最快捷也是最有效果的方式,跟着视频中老师的思路,从基础到深入,还是很容易入门的。

**五、实战案例**
纸上得来终觉浅,要学会跟着视频一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。

做了那么多年开发,自学了很多门编程语言,我很明白学习资源对于学一门新语言的重要性,这些年也收藏了不少的Python干货,对我来说这些东西确实已经用不到了,但对于准备自学Python的人来说,或许它就是一个宝藏,可以给你省去很多的时间和精力。
别在网上瞎学了,我最近也做了一些资源的更新,只要你是我的粉丝,这期福利你都可拿走。
我先来介绍一下这些东西怎么用,文末抱走。
* * *
**(1)Python所有方向的学习路线(新版)**
这是我花了几天的时间去把Python所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。
最近我才对这些路线做了一下新的更新,知识体系更全面了。

**(2)Python学习视频**
包含了Python入门、爬虫、数据分析和web开发的学习视频,总共100多个,虽然没有那么全面,但是对于入门来说是没问题的,学完这些之后,你可以按照我上面的学习路线去网上找其他的知识资源进行进阶。

**(3)100多个练手项目**
我们在看视频学习的时候,不能光动眼动脑不动手,比较科学的学习方法是在理解之后运用它们,这时候练手项目就很适合了,只是里面的项目比较多,水平也是参差不齐,大家可以挑自己能做的项目去练练。

**(4)200多本电子书**
这些年我也收藏了很多电子书,大概200多本,有时候带实体书不方便的话,我就会去打开电子书看看,书籍可不一定比视频教程差,尤其是权威的技术书籍。
基本上主流的和经典的都有,这里我就不放图了,版权问题,个人看看是没有问题的。
**(5)Python知识点汇总**
知识点汇总有点像学习路线,但与学习路线不同的点就在于,知识点汇总更为细致,里面包含了对具体知识点的简单说明,而我们的学习路线则更为抽象和简单,只是为了方便大家只是某个领域你应该学习哪些技术栈。

**(6)其他资料**
还有其他的一些东西,比如说我自己出的Python入门图文类教程,没有电脑的时候用手机也可以学习知识,学会了理论之后再去敲代码实践验证,还有Python中文版的库资料、MySQL和HTML标签大全等等,这些都是可以送给粉丝们的东西。

**这些都不是什么非常值钱的东西,但对于没有资源或者资源不是很好的学习者来说确实很不错,你要是用得到的话都可以直接抱走,关注过我的人都知道,这些都是可以拿到的。**
**了解详情:https://docs.qq.com/doc/DSnl3ZGlhT1RDaVhV**