Par rapport au salon de discussion Java, Python peut également le faire. Et cela peut être fait avec plus d’élégance. Vous apprécierez certainement le fait qu'il y ait beaucoup moins de sockets Python de différents flux.
Quant au contenu lié aux points de connaissance, je n'entrerai pas dans les détails ici.
Mode UDP
Côté serveur
# coding:utf-8 # __author__ = 'Mark sinoberg' # __date__ = '2016/7/7' # __Desc__ = 创建一个简单的套接字监听请求 import socket HOST = '192.168.59.255' PORT = 9998 s = socket.socket(socket.AF_INET,socket.SOCK_DGRAM) s.bind(('',PORT)) print '套接字已启动!' while True: data,addr = s.recvfrom(1024) print addr,str(' : ')+data
Client
# coding:utf-8 # __author__ = 'Mark sinoberg' # __date__ = '2016/7/7' # __Desc__ = socket的客户端的简单实现 import socket PORT = 9998 HOST = '192.168.59.255' s = socket.socket(socket.AF_INET,socket.SOCK_DGRAM) words = raw_input('Client:') while words != 'quit': s.sendto(words,(HOST,PORT)) words = raw_input('Client:') s.close()
N'est-ce pas très simple. Ce à quoi nous devons faire attention, c'est que le deuxième paramètre du socket est SOCK_DGRAM. Parce que c'est différent de SOCK_STREAM en mode TCP.
Mode TCP
Côté serveur
# coding:utf-8 # __author__ = 'Mark sinoberg' # __date__ = '2016/7/7' # __Desc__ = 简单的tcpsocket的实现 from socket import * from time import ctime HOST = '' PORT = 9999 BUFFERSIZE = 1024 ADDRESS = (HOST,PORT) s = socket(AF_INET,SOCK_STREAM) s.bind(ADDRESS) s.listen(5) while True: print 'Waiting for clients cennect!' tcpclient,addr = s.accept() print 'Connected By ',addr while True: try: data = tcpclient.recv(BUFFERSIZE) except Exception,e: print e.message tcpclient.close() break if not data: print "No Data received!" break senddata = 'Hi,you send me:[%s]%s'%(ctime(),data.encode('utf8')) tcpclient.send(senddata.encode('utf8')) print addr,' Says:',ctime(),data.encode('utf8') tcpclient.close() s.close()
Client
# coding:utf-8 # __author__ = 'Mark sinoberg' # __date__ = '2016/7/7' # __Desc__ = 简单的tcp socket客户端的实现 from socket import * class TcpClient: # HOST = 'localhost' PORT = 9999 HOST = '192.168.59.225' BUFFSIZ = 1024 ADDR = (HOST,PORT) def __init__(self): self.client = socket(AF_INET,SOCK_STREAM) self.client.connect((self.HOST,self.PORT)) while True: senddata = raw_input('>>>') if not senddata: print 'Please input some words!\n>>>' continue if senddata == "quit": break self.client.send(senddata.encode('utf8')) recvdata = self.client.recv(self.BUFFSIZ) if not recvdata: break print recvdata.encode('utf8') if __name__ == "__main__": client = TcpClient()
Résultat de la démonstration du mode TCP ( Remarque : ouvrez d'abord le côté serveur)
Côté serveur
D:SoftwarePython2python.exe E:/Code/Python/MyTestSet/sockettest/ SimpleTCPServer.py
En attente des clients cennect !
Connecté par ('192.168.59.225', 63095)
('192.168.59.225', 63095) Dit : jeu. 07 juillet 16:01:10 2016 Bonjour tout le monde
('192.168.59.225', 63095) Dit : jeu. 07 juillet 16:01:15 2016 haode
Aucune donnée reçue !
En attente de clients cennect !
Client
D:SoftwarePython2python.exe E:/Code/Python/MyTestSet/sockettest/SimpleTcpClient.py
>>>Bonjour tout le monde
Salut, vous envoyez-moi : [Jeudi 7 juillet 16:01:10 2016]Bonjour tout le monde
>>>
Veuillez saisir quelques mots !
>>>
>> ;haode
Salut, vous m'envoyez :[Jeudi 7 juillet 16:01:15 2016]haode
>>>quitter
Processus terminé avec le code de sortie 0
Résumé
Il est très simple d'utiliser simplement TCP ou UDP, mais si vous souhaitez mieux utiliser ces deux protocoles, vous devez les concevoir avec soin.
Ce que je veux souligner ici, c'est qu'il suffit de faire attention aux paramètres spécifiés lorsque TCP et UDP créent des sockets.
Ce qui précède représente l'intégralité du contenu de cet article. J'espère qu'il sera utile à l'apprentissage de chacun. J'espère également que tout le monde soutiendra le site Web PHP chinois.
Pour plus d'articles liés à l'implémentation du code Python des salons de discussion, veuillez faire attention au site Web PHP chinois !