python取代netcat过程分析
作者:以笔为剑的唐吉坷德 时间:2021-07-22 17:32:51
首先解释几个概念:
TCP:TCP是因特网中的传输层协议,使用三次握手协议建立连接。
IP:Internet Protocol协议的英文名直译就是:因特网协议。
UDP:和TCP一样,是网络传输层协议,UDP提供了无连接通信,且不对传送数据包进行可靠性保证,适合于一次传输少量数据。
scoket:
网络上的两个程序通过一个双向的通信连接实现数据的交换,这个连接的一端称为一个socket。建立网络通信连接至少要一对端口号(socket)。socket本质是编程接口(API),对TCP/IP的封装,TCP/IP也要提供可供程序员做网络开发所用的接口,这就是Socket编程接口;HTTP是轿车,提供了封装或者显示数据的具体形式;Socket是发动机,提供了网络通信的能力。
Linux中Netcat命令整理参考:https://www.jb51.net/article/134906.htm
我们所要学习的,就是用python模仿netcat来做一些很神奇的事情。
创建一个简单的TCP客户端:
# -*- coding: utf-8 -*-
import socket
target_host = "www.baidu.com"
target_port = 80
#建立socket对象,建立包含AF_INET,和SOCK_STREAM参数的socket对象。AF_INET参数锁门我们使用IPV4地址,SOCK_STREAM说明这是一个TCP客户端
client = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
#连接客户端
client.connect((target_host, target_port))
#send some data
client.send("GET / HTTP/1.1\r\nHsot:baidu.com\r\n\r\n")
#get some data
response = client.recv(4096)
print response
创建一个基础的TCP服务器:
# -*- coding: utf-8 -*-
import socket
import threading
bind_ip = '0.0.0.0'
bind_port=9999
server = socket.socket(socket.AF_INET,socket.SOCK_STREAM)
server.bind((bind_ip, bind_port))
server.listen(5)
print "[+]listening on %s, %d"%(bind_ip,bind_port)
#创建客户处理线程
def handle_client(client_socket):
#打印客户端发送得到的内容
request = client_socket.recv(1024)
print "[*]Recived:%s"%request
#返回数据包
client_socket.send("Fuck You All!")
client_socket.close()
while True:
client, addr=server.accept()
print "[*]Accepted connection from:%s:%d"%(addr[0], addr[1])
#挂起客户端,处理传入数据
client_handler = threading.Thread(target=handle_client,args=(client,))
client_handler.start()
由于之前没有接触过,于是对TCP服务器和TCP客户端有一定的疑问,于是开始寻找答案。
1、客户根据用户提供的IP地址连接到相应的服务器;
2、服务器等待客户的连接,一旦连接成功,则显示客户的IP地址、端口号,并向客户端发送字符串;
3、客户接收服务器发送的信息并显示。
如果没有理解错的话,应该是客户端控制服务端。
将上面的TCP客户端的target_ip修改后,可以控制该服务端。修改send()函数。
来源:http://blog.csdn.net/Greepex/article/details/72823546
标签:python,netcat
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
Python3如何对urllib和urllib2进行重构
2022-05-18 08:48:52
Python 标准库 fileinput与文件迭代器
2023-10-31 22:36:50
基于jQuery的自动完成插件
2011-02-05 10:55:00
判断浏览器是否接受 Cookie
2009-07-28 17:52:00
网马解密大讲堂——网马解密中级篇(Document.write篇)
2009-09-16 16:16:00
Python实现将mp3音频格式转换为wav格式
2023-09-18 15:50:02
![](https://img.aspxhome.com/file/2023/7/62557_0s.png)
利用Python 实现图片转字符画
2022-05-06 11:31:01
![](https://img.aspxhome.com/file/2023/0/92510_0s.png)
Python开发之迭代器&生成器的实战案例分享
2021-03-18 17:34:33
Python多重继承的方法解析执行顺序实例分析
2021-06-08 04:34:51
![](https://img.aspxhome.com/file/2023/3/65983_0s.png)
使用Python+Splinter自动刷新抢12306火车票
2023-09-17 18:38:52
![](https://img.aspxhome.com/file/2023/8/91958_0s.jpg)
centos下安装配置phpMyAdmin的方法步骤
2023-11-09 01:27:11
YUI学习笔记(4)
2009-03-10 18:25:00
如何用Frontpage下载别人的网站模板
2008-03-03 12:58:00
![](https://img.aspxhome.com/file/uploadpic/20083/3/200833125925418.gif)
python人工智能tensorflow函数tensorboard使用方法
2021-04-21 14:52:46
![](https://img.aspxhome.com/file/2023/7/88887_0s.png)
windows下python安装pip方法详解
2023-12-13 19:43:16
![](https://img.aspxhome.com/file/2023/8/72918_0s.png)
兼容FF的图片切换代码
2009-09-26 20:15:00
各种SQL语句速查手册
2007-09-27 19:31:00
解决python DataFrame 打印结果不换行问题
2023-11-20 23:12:25
![](https://img.aspxhome.com/file/2023/4/84084_0s.jpg)
Python list与NumPy array 区分详解
2021-08-25 04:12:37
Python3中最常用的5种线程锁实例总结
2022-06-19 08:21:02