Posted in Python onOctober 12, 2019
本文实例讲述了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相关内容可查看本站专题:《Python Socket编程技巧总结》、《Python数据结构与算法教程》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》、《Python入门与进阶经典教程》及《Python文件与目录操作技巧汇总》
希望本文所述对大家Python程序设计有所帮助。
Python 网络编程之TCP客户端/服务端功能示例【基于socket套接字】
- Author -
houyanhua1声明:登载此文出于传递更多信息之目的,并不意味着赞同其观点或证实其描述。
Reply on: @reply_date@
@reply_contents@