Python實(shí)現(xiàn)的使用telnet登陸聊天室實(shí)例
本文實(shí)例講述了Python實(shí)現(xiàn)的使用telnet登陸聊天室。分享給大家供大家參考。具體如下:
前久在家學(xué)習(xí)Python的時(shí)候?qū)懙囊粋€(gè)簡(jiǎn)單的聊天室,可以使用telnet來登陸。
遺憾的是現(xiàn)在對(duì)中文的支持很差,英文聊天倒是沒什么問題了。
功能很簡(jiǎn)單的,應(yīng)該沒有你想象的那么強(qiáng)大,但是你如果有興趣的話可以試試的。
另外,讓我驚奇的是它可以在Android的平板上運(yùn)行SL4A的Python解釋器上運(yùn)行(需要稍微改幾句代碼,貌似是編碼的那個(gè)地方,我記不清了)。
現(xiàn)在這個(gè)是可以在PC上跑起來的。
廢話不多,直接放代碼了,就一個(gè)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()
有了這個(gè)服務(wù)器程序之后就可以了(當(dāng)然前提是你安裝的Python解釋器),沒有客戶端的,那么你會(huì)問怎么開始聊天呢?
下面開始介紹怎么開始聊天,首先你把這個(gè)文件運(yùn)行起來,如下圖可以看到服務(wù)器正在等待客戶端登陸了:

客戶端直接使用telnet命令登陸,注意端口應(yīng)該和服務(wù)器的一樣,命令為:telnet 127.0.0.1 9011,自動(dòng)打開telnet控制臺(tái),輸入自己的名字吧:

現(xiàn)在你在看看服務(wù)器端的控制臺(tái)界面,可以看到記錄了登陸消息:

繼續(xù)使用telnet登陸另外的用戶之后就可以聊天了:

功能很簡(jiǎn)陋了,不過這讓我想起了二三十年前的事,嘿嘿,那時(shí)候應(yīng)該就是這樣子聊天的了吧,生在這個(gè)時(shí)代的我們永遠(yuǎn)都體會(huì)不到那種樂趣了。
希望本文所述對(duì)大家的Python程序設(shè)計(jì)有所幫助。
- python實(shí)現(xiàn)多人聊天室
- python socket多線程通訊實(shí)例分析(聊天室)
- Python實(shí)現(xiàn)基于C/S架構(gòu)的聊天室功能詳解
- 小小聊天室Python代碼實(shí)現(xiàn)
- Python socket C/S結(jié)構(gòu)的聊天室應(yīng)用實(shí)現(xiàn)
- python編寫簡(jiǎn)易聊天室實(shí)現(xiàn)局域網(wǎng)內(nèi)聊天功能
- python實(shí)現(xiàn)簡(jiǎn)單多人聊天室
- 基于python實(shí)現(xiàn)聊天室程序
- Python socket實(shí)現(xiàn)簡(jiǎn)單聊天室
- python實(shí)現(xiàn)簡(jiǎn)易聊天室(Linux終端)
相關(guān)文章
python自動(dòng)化調(diào)用百度api解決驗(yàn)證碼
這篇文章主要介紹了python自動(dòng)化調(diào)用百度api解決驗(yàn)證碼,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-04-04
Python Django實(shí)現(xiàn)個(gè)人博客系統(tǒng)的搭建
個(gè)人博客是一個(gè)非常好的平臺(tái),可以讓人們分享自己的知識(shí)和經(jīng)驗(yàn),也可以讓人們交流和互動(dòng)。在這篇文章中,我們將介紹如何使用Python Django框架來開發(fā)一個(gè)個(gè)人博客系統(tǒng),希望對(duì)大家有所幫助2023-04-04
pandas series序列轉(zhuǎn)化為星期幾的實(shí)例
下面小編就為大家分享一篇pandas series序列轉(zhuǎn)化為星期幾的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-04-04
jupyter 實(shí)現(xiàn)notebook中顯示完整的行和列
這篇文章主要介紹了jupyter 實(shí)現(xiàn)notebook中顯示完整的行和列,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-04-04
Python?自動(dòng)控制原理?control的詳細(xì)解說
這篇文章主要介紹了Python自動(dòng)控制原理control的詳細(xì)解說,文章圍繞主題展開對(duì)Python?control的介紹,具有一定的參考價(jià)值,需要的朋友可以參考一下2022-07-07
Matplotlib學(xué)習(xí)筆記之plt.xticks()用法
在matplotlib中ticks表示的是刻度,而刻度有兩層意思,一個(gè)是刻標(biāo)(locs),一個(gè)是刻度標(biāo)簽(tick?labels),下面這篇文章主要給大家介紹了關(guān)于Matplotlib學(xué)習(xí)筆記之plt.xticks()用法的相關(guān)資料,需要的朋友可以參考下2022-09-09
Python PyQt5 Pycharm 環(huán)境搭建及配置詳解(圖文教程)
這篇文章主要介紹了Python PyQt5 Pycharm 環(huán)境搭建及配置詳解,文中通過圖文介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-07-07

