Python實現(xiàn)的使用telnet登陸聊天室實例
本文實例講述了Python實現(xiàn)的使用telnet登陸聊天室。分享給大家供大家參考。具體如下:
前久在家學(xué)習(xí)Python的時候?qū)懙囊粋€簡單的聊天室,可以使用telnet來登陸。
遺憾的是現(xiàn)在對中文的支持很差,英文聊天倒是沒什么問題了。
功能很簡單的,應(yīng)該沒有你想象的那么強大,但是你如果有興趣的話可以試試的。
另外,讓我驚奇的是它可以在Android的平板上運行SL4A的Python解釋器上運行(需要稍微改幾句代碼,貌似是編碼的那個地方,我記不清了)。
現(xiàn)在這個是可以在PC上跑起來的。
廢話不多,直接放代碼了,就一個py文件而已,而且注釋是亂七八糟的,編碼風(fēng)格也不好(好神似我在用類C語言的習(xí)慣)。
# Filename: ChatRoomServer.py import threading import datetime import socket # a simple log function def log(lg): print(lg) # Chat room server listen thread class, this class is use for listening client login # when a client request to connect server, this class will start a connect thread class ServerListenThread(threading.Thread): def __init__(self, hostname, port, accept): threading.Thread.__init__(self) self.hostname = hostname self.port = port self.accept = accept self.sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM) self.sock.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1) self.sock.bind((hostname, port)) self.sock.listen(0) log('ServerIp:%s ServerPort:%s waiting for client...'%self.sock.getsockname()) def run(self): clientid = 1 while True: client, cltadd = self.sock.accept() log('a request from Id=%s%s'%('%d Address:'%clientid , cltadd)) if self.accept(clientid, client): clientid = clientid + 1 # Connect thread class, this class is use for connecting with client and receiving client's message class ServerConnectThread(threading.Thread): def __init__(self, clientid, client, encoding, receive, disconnect): threading.Thread.__init__(self) self.client = client self.clientid = clientid self.encoding = encoding self.receive = receive self.disconnect = disconnect self.clientname = None self.inputs = self.client.makefile('rb', 0) self.outputs = self.client.makefile('wb', 0) def run(self): self.sendstring('Input your name:') while True: string = self.readline() if string: string = string.lstrip() if len(string)>0: self.receive(self, string) else: self.inputs.close() self.outputs.close() break if self.clientname: self.disconnect(self) def sendstring(self, string): self.sendbytes(bytes(string, self.encoding)) def sendbytes(self, bts): self.outputs.write(bts) def readline(self): rec = self.inputs.readline() if rec: string = bytes.decode(rec, self.encoding) if len(string)>2: string = string[0:-2] else: string = ' ' else: string = False return string # Chat room server class, this class is constitute of a listen thread and many connect thread class ChatRoomServer: def __init__(self, ip='0.0.0.0', port=9113, encoding='utf-8'): self.hostname = ip self.encoding = encoding self.port = port self.clients = {} self.clientnames = {} def whenconnect(self, clientid, client): log('a connect with Id=%s%s'%('%d Address:'%clientid , client.getpeername())) connect = ServerConnectThread(clientid, client, self.encoding, self.whenreceive, self.whenexit) connect.start() return True def whenreceive(self, client, string): log('frome %d, receive:%s (%d)'%(client.clientid, string, len(string))) if client.clientname: if string[0]=='.': self.handlecmd(client, string[1:]) else: now = datetime.datetime.now() sendstring = '%s %s\r\n %s\r\n'%(now, client.clientname, string) self.sendtoall(sendstring, client) else: if self.clientnames.__contains__(string): client.sendstring('%s is exited!!!\r\n'%string) else: client.clientname = string client.sendstring('Hell, %s!!!\r\n'%client.clientname) self.addclient(client) return True def whenexit(self, client): self.delclient(client) return True def handlecmd(self, client, cmd): log('cmd: %s'%cmd) if cmd=='user': client.sendstring('User list(%d):\r\n'%len(self.clients)) for i in self.clients: clt = self.clients[i] client.sendstring(' %d\t%s\r\n'%(clt.clientid, clt.clientname)) else: client.sendstring('Unknow command: %s:\r\n'%cmd) def start(self): serverlisten = ServerListenThread(self.hostname, self.port, self.whenconnect) serverlisten.start() def sendtoall(self, string, notfor): sends = bytes(string, self.encoding) for i in self.clients: if not(notfor and notfor.clientid==i): self.clients[i].sendbytes(sends) def addclient(self, client): self.sendtoall('%s logined!!!\r\n'%client.clientname, client) self.clients[client.clientid] = client self.clientnames[client.clientname] = client.clientid def delclient(self, client): self.sendtoall('%s logouted!!!\r\n'%client.clientname, client) del self.clients[client.clientid] del self.clientnames[client.clientname] # start a chat room server ChatRoomServer().start()
有了這個服務(wù)器程序之后就可以了(當(dāng)然前提是你安裝的Python解釋器),沒有客戶端的,那么你會問怎么開始聊天呢?
下面開始介紹怎么開始聊天,首先你把這個文件運行起來,如下圖可以看到服務(wù)器正在等待客戶端登陸了:
客戶端直接使用telnet命令登陸,注意端口應(yīng)該和服務(wù)器的一樣,命令為:telnet 127.0.0.1 9011,自動打開telnet控制臺,輸入自己的名字吧:
現(xiàn)在你在看看服務(wù)器端的控制臺界面,可以看到記錄了登陸消息:
繼續(xù)使用telnet登陸另外的用戶之后就可以聊天了:
功能很簡陋了,不過這讓我想起了二三十年前的事,嘿嘿,那時候應(yīng)該就是這樣子聊天的了吧,生在這個時代的我們永遠都體會不到那種樂趣了。
希望本文所述對大家的Python程序設(shè)計有所幫助。
相關(guān)文章
Python Django實現(xiàn)個人博客系統(tǒng)的搭建
個人博客是一個非常好的平臺,可以讓人們分享自己的知識和經(jīng)驗,也可以讓人們交流和互動。在這篇文章中,我們將介紹如何使用Python Django框架來開發(fā)一個個人博客系統(tǒng),希望對大家有所幫助2023-04-04pandas series序列轉(zhuǎn)化為星期幾的實例
下面小編就為大家分享一篇pandas series序列轉(zhuǎn)化為星期幾的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-04-04jupyter 實現(xiàn)notebook中顯示完整的行和列
這篇文章主要介紹了jupyter 實現(xiàn)notebook中顯示完整的行和列,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-04-04Matplotlib學(xué)習(xí)筆記之plt.xticks()用法
在matplotlib中ticks表示的是刻度,而刻度有兩層意思,一個是刻標(locs),一個是刻度標簽(tick?labels),下面這篇文章主要給大家介紹了關(guān)于Matplotlib學(xué)習(xí)筆記之plt.xticks()用法的相關(guān)資料,需要的朋友可以參考下2022-09-09Python PyQt5 Pycharm 環(huán)境搭建及配置詳解(圖文教程)
這篇文章主要介紹了Python PyQt5 Pycharm 環(huán)境搭建及配置詳解,文中通過圖文介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-07-07