一. 客户端应用程序开发示例
import socket
if __name__ == '__main__':
tcp_client_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
tcp_client_socket.connect(("192.168.***.**", 8080))
send_data = "你好服务端,我是客户!".encode("gbk")
tcp_client_socket.send(send_data)
recv_data = tcp_client_socket.recv(1024)
recv_content = recv_data.decode("gbk")
print("接收服务端的数据为:", recv_content)
tcp_client_socket.close()
二. 服务端应用程序开发示例
import socket
if __name__ == '__main__':
tcp_server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
tcp_server_socket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, True)
tcp_server_socket.bind(("*******", 8080))
tcp_server_socket.listen(128)
service_client_socket, ip_port = tcp_server_socket.accept()
print("客户端的TP地址和端口号为:", ip_port)
recv_data = service_client_socket.recv(1024)
recv_content = recv_data.decode("gbk")
print("接收客户端的数据为:", recv_content)
send_data = "这是发送的数据".encode("gbk")
service_client_socket.send(send_data)
service_client_socket.close()
tcp_server_socket.close()
注:
1.因为端口的使用具有延迟,需要端口复用,让程序退出时端口号立即释放。 2.listen 后的套接字是被动套接字,只负责接收新的客户端的连接请求,不能收发消息。 3.关闭 listen 后的套接字意味着服务端的套接字关闭了,会导致新的客户端不能连接服务端,但是之前已经接成功的客户端还能正常通信。 4.当客户端的套接字调用 close 后,服务器端的 recv 会解阻塞,返回的数据长度为0,服务端可以通过返回数据的长度来判断客户端是否已经下线,反之服务端关闭套接字,客户端的 recv 也会解阻塞,返回的数据长度也为0。
|