怎么使用python写一个最简单的扫描器(脱离脚本小子第一步)_python扫描器

70 阅读7分钟

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学习资料,包含面试题、简历资料等具体看下方。  
   
 ![](https://p6-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/6e035c55162d47a398c64a06c5ab68aa~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg55So5oi3NTc5MjMwMTY3MDI=:q75.awebp?rk3s=f64ab15b&x-expires=1771407517&x-signature=cdN4dG8K6ZnP%2FSdJuGQqTQUhxBI%3D)


**一、Python所有方向的学习路线**


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


![img](https://p6-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/22730d922c8f4ff284c84de628e004dc~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg55So5oi3NTc5MjMwMTY3MDI=:q75.awebp?rk3s=f64ab15b&x-expires=1771407517&x-signature=Hkfx4oJdGQP03k%2FFiSgbZv8TeCI%3D)  
 ![img](https://p6-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/217cdc68bac84b979fb3cf1c9f77497f~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg55So5oi3NTc5MjMwMTY3MDI=:q75.awebp?rk3s=f64ab15b&x-expires=1771407517&x-signature=pJfnCXTiZi8VWpvOJQ0RxQCvN2A%3D)


**二、Python必备开发工具**


工具都帮大家整理好了,安装就可直接上手!![img](https://p6-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/7e4b721f55d64d608b0b12f412d31673~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg55So5oi3NTc5MjMwMTY3MDI=:q75.awebp?rk3s=f64ab15b&x-expires=1771407517&x-signature=HwKnMk98iODELlcxRxuUQUMoVDc%3D)


**三、最新Python学习笔记**


当我学到一定基础,有自己的理解能力的时候,会去阅读一些前辈整理的书籍或者手写的笔记资料,这些笔记详细记载了他们对一些技术点的理解,这些理解是比较独到,可以学到不一样的思路。


![img](https://p6-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/7c96c6a6d11a40a3afd2370819a28294~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg55So5oi3NTc5MjMwMTY3MDI=:q75.awebp?rk3s=f64ab15b&x-expires=1771407517&x-signature=B9fFB%2FezWoSGLWZdALpNqFIvYRE%3D)


**四、Python视频合集**


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


![img](https://p6-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/653924c3cce245a9905d86dfd558505c~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg55So5oi3NTc5MjMwMTY3MDI=:q75.awebp?rk3s=f64ab15b&x-expires=1771407517&x-signature=jQ74fW3mBCqtAy3dImpKKXnqjlE%3D)


**五、实战案例**


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


![img](https://p6-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/47ebb87052be4bb48130828051e58c4a~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg55So5oi3NTc5MjMwMTY3MDI=:q75.awebp?rk3s=f64ab15b&x-expires=1771407517&x-signature=6AJl0n5Vbm3%2BaFO%2FjbP38HNfY6s%3D)




做了那么多年开发,自学了很多门编程语言,我很明白学习资源对于学一门新语言的重要性,这些年也收藏了不少的Python干货,对我来说这些东西确实已经用不到了,但对于准备自学Python的人来说,或许它就是一个宝藏,可以给你省去很多的时间和精力。



别在网上瞎学了,我最近也做了一些资源的更新,只要你是我的粉丝,这期福利你都可拿走。

我先来介绍一下这些东西怎么用,文末抱走。

* * *



**(1)Python所有方向的学习路线(新版)**

这是我花了几天的时间去把Python所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。



最近我才对这些路线做了一下新的更新,知识体系更全面了。



![在这里插入图片描述](https://p6-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/98e12d3b40d748a8900318dc239f04f1~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg55So5oi3NTc5MjMwMTY3MDI=:q75.awebp?rk3s=f64ab15b&x-expires=1771407517&x-signature=VkDhxNOrcWvFkga1Ml8KGVWEjrU%3D)



**(2)Python学习视频**



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



![在这里插入图片描述](https://p6-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/96568f4f4f4b4e8ebf6df39c85bce807~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg55So5oi3NTc5MjMwMTY3MDI=:q75.awebp?rk3s=f64ab15b&x-expires=1771407517&x-signature=easISoB0q5SyxF2Q0DrVfxvKtNw%3D)



**(3)100多个练手项目**

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



![在这里插入图片描述](https://p6-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/290dad4cbb094feebfc2d20099a7821a~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg55So5oi3NTc5MjMwMTY3MDI=:q75.awebp?rk3s=f64ab15b&x-expires=1771407517&x-signature=uSJNcAwfluJNh3z5th5wkeZc4GI%3D)



**(4)200多本电子书**  

  

这些年我也收藏了很多电子书,大概200多本,有时候带实体书不方便的话,我就会去打开电子书看看,书籍可不一定比视频教程差,尤其是权威的技术书籍。



基本上主流的和经典的都有,这里我就不放图了,版权问题,个人看看是没有问题的。



**(5)Python知识点汇总**

知识点汇总有点像学习路线,但与学习路线不同的点就在于,知识点汇总更为细致,里面包含了对具体知识点的简单说明,而我们的学习路线则更为抽象和简单,只是为了方便大家只是某个领域你应该学习哪些技术栈。



![在这里插入图片描述](https://p6-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/d4b7a9f1b3804b07a236e6d2d7a4d93e~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg55So5oi3NTc5MjMwMTY3MDI=:q75.awebp?rk3s=f64ab15b&x-expires=1771407517&x-signature=Ffrw9fztGjJzYyBvown9Uf8uQl0%3D)



**(6)其他资料**



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



![在这里插入图片描述](https://p6-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/10cb281eddee44248657bf48eb049c73~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg55So5oi3NTc5MjMwMTY3MDI=:q75.awebp?rk3s=f64ab15b&x-expires=1771407517&x-signature=dRBwA4DWjED8Ga1Cvo6xoIen00E%3D)

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



**了解详情:https://docs.qq.com/doc/DSnl3ZGlhT1RDaVhV**