本文实例讲述了Python网络编程之TCP客户端/服务端功能。分享给大家供大家参考,具体如下
本文实例讲述了Python 网络编程之TCP客户端/服务端功能。分享给大家供大家参考,具体如下:
demo.py(TCP客户端):
import socket
def main():
# 1. 创建tcp的套接字
tcp_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
# 2. 链接服务器
# tcp_socket.connect(("192.168.33.11", 7890))
server_ip = input("请输入要链接的服务器的ip:")
server_port = int(input("请输入要链接的服务器的port:"))
server_addr = (server_ip, server_port)
tcp_socket.connect(server_addr)
# 3. 发送数据/接收数据
send_data = input("请输入要发送的数据:")
tcp_socket.send(send_data.encode("utf-8"))
# 接收数据。 会阻塞代码,直到接收到数据
recv_data = tcp_socket.recv(1024) # 1024表示本次接收的最大字节数。
print(recv_data.decode("utf-8"))
# 4. 关闭套接字
tcp_socket.close()
if __name__ == "__main__":
main()
demo.py(TCP服务端):
import socket
def main():
# 1. 创建套接字 socket
tcp_server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
# 设置当服务器先close 即服务器端4次挥手之后资源能够立即释放,这样就保证了,下次运行程序时 可以立即绑定7890端口 (如果服务端先close,再启动服务端就不会报端口被占用的错误。)
tcp_server_socket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
# 2. 绑定本机ip和端口号 bind
tcp_server_socket.bind(("", 7890))
# 3. 监听客户端的链接请求 listen (由主动去链接服务器,变成被客户端链接)
tcp_server_socket.listen(128) # 128影响链接客户端的数量(并发量)(和操作系统也有关)
# 4. 接受客户端的链接 accept。 会阻塞代码,直到有客户端链接
new_client_socket, client_addr = tcp_server_socket.accept()
print(client_addr) # ("192.168.33.109",53766) 客户端的ip和端口
# 接收客户端发送过来的数据。 会阻塞代码,直到接收到数据
recv_data = new_client_socket.recv(1024) # 1024表示本次接收的最大字节数。
print(recv_data.decode("utf-8")) # 如果recv_data为空,表示客户端断开链接
# 写数据给客户端
new_client_socket.send("hahahghai-----ok-----".encode("utf-8"))
# 关闭套接字
new_client_socket.close() # 与客户端通信的套接字
tcp_server_socket.close() # 服务器套接字
if __name__ == "__main__":
main()
Python
网络编程
TCP
客户端
服务端
socket套接字