一:socket的由来
socket 是一种计算机网络数据结构,中文译名:套接字
socket 最初是为同一主机上的应用程序创建,是主机上运行的一个程序与另一个程序之间 可以完成数据通信操作,程序也称为进程,就出现了不同进程间进行数据交互的操作,因为 交互的模式不同,所以也一般将程序中的套接字区分为两种
面向文件的套接字:通过文件进行数据交互
面向网络的套接字:通过网络进行数据交互-
python中的套接字
套接字模型对象,为了能明确的表示网络中一台数据交互的主机,需要通过 IP 地址寻址确 定主机位置,通过 PORT 端口号确定主机交互接口在网络套接字交互过程中,出现了两种类型的套接字模型: 1. 面向连接的套接字模型 2. 面向无连接的套接字模型
面向连接的套接字模型,在进行网络数据传输过程中,首先要创建一个连接模型,通过指定 的连接模型进行数据的交互,类似我们生活中拨打电话一样,首先保证通话连接的基础上才 能完成通话内容的交互,比较经典的如 TCP 端对端传输协议就是面向连接的套接字对象 (比较可靠的传输)
面向无连接的套接字模型,在进行网络数据传输过程中,不需要有效的网络连接模型,在数 据传输过程中只负责发送/接受,不保证数据的完整性和实效性;类似我们生活中的广播电 台、电视信号等等,操作效率要比面向连接的套接字模型更加高效;比较经典的 UDP 广播 协议使用的就是面向无连接的套接字对象
二: socket的基本语法
s.bind() 绑定(主机名称、端口)到一个套接字上
s.listen() 设置并启动 TCP 监听
s.accept() 等待客户端连接
s.connect() 连接指定服务器
s.connect_ex() 连接指定服务器,如果出现错误返回错误信息
s.recv() 接受 TCP 消息
s.recv_into() 接受 TCP 消息到缓冲区
s.send() 发送 TCP 消息
s.sendall() 完整发送 TCP 消息
s.recvfrom() 接受 UDP 消息
s.recvfrom_into() 接受 UDP 消息到缓冲区
s.sendto() 发送 UDP 消息
s.shutdown() 关闭连接对象
s.close() 关闭套接字对象
三:案例演示
"""TCP服务模块"""
# 引入需要的模块
import socket
# 定义连接信息
HOST = '' # 表示当前主机的IP
PORT= 9000 # 为了不影响本机系统和程序的运行,最好选择8000以上的端口, 这里我选择9000
ADDRESS = (HOST, PORT)
# 定义一个读写数据的缓冲字节大小
BUFFERR = 1024
# 创建一个TCP服务端套接字对象
tcp_server = socket.socket(socket.AF_INIT, socket.SOCK_STREAM)
# 绑定主机端口号
tcp_server.bind(ADDRESS)
# 监听端口:参数 排队的客户端
tcp_server.listen(5)
while True:
# 等待客户端接入,建立连接
print("waiting for connect.....")
server_socket, addr = tcp_server.accept()
print("client already context! welcome to server: ", addr)
while True:
# 发送一个消息给客户端
info = input("请输入你要发送的信息:")
server_socket.send(info.encode("utf-8"))
# 接收客户端发送的消息
msg = server.recv(BUFFER)
print("client:", msg.decode("utf-8"))
if msg == b'BYE':
# 关闭套接字
server_socket.close()
break
# 程序结束时,关闭服务端
tcp_server.close() # 该语句永远不会被执行到,是一个小问题,后期会修改
客户端代码:
'''TCP客户端'''
# 引入需要的模块
import socket
# 定义连接信息
TARGET_HOST = '192.168.13.17'
TARGET_PORT = 9000
TARGET_ADDRESS = (TARGET_HOST, TARGET_PORT)
BUFFER = 1024
# 创建一个tcp套接字对象
tcp_client = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
# 连接指定的主机
tcp_client.connect(TARGET_ADDRESS)
# 收发消息
while True:
# 接受服务器消息
msg = tcp_client.recv(BUFFER)
print("server:", msg.decode("utf-8"))
# 向服务器发送消息
info = input("请输入您要发送的消息:")
tcp_client.send(info.encode("utf-8"))
if info == "BYE":
# 关闭套接字
tcp_client.close()
break
# print("客户端退出")