本文实例讲述了Python实现的使用telnet登陆聊天室。分享给大家供大家参考。具体如下:
前久在家学习Python的时候写的一个简单的聊天室,可以使用telnet来登陆。
遗憾的是现在对中文的支持很差,英文聊天倒是没什么问题了。
功能很简单的,应该没有你想象的那么强大,但是你如果有兴趣的话可以试试的。
另外,让我惊奇的是它可以在Android的平板上运行SL4A的Python解释器上运行(需要稍微改几句代码,貌似是编码的那个地方,我记不清了)。
现在这个是可以在PC上跑起来的。
废话不多,直接放代码了,就一个py文件而已,而且注释是乱七八糟的,编码风格也不好(好神似我在用类C语言的习惯)。
# 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()
有了这个服务器程序之后就可以了(当然前提是你安装的Python解释器),没有客户端的,那么你会问怎么开始聊天呢?
下面开始介绍怎么开始聊天,首先你把这个文件运行起来,如下图可以看到服务器正在等待客户端登陆了:
客户端直接使用telnet命令登陆,注意端口应该和服务器的一样,命令为:telnet 127.0.0.1 9011,自动打开telnet控制台,输入自己的名字吧:
现在你在看看服务器端的控制台界面,可以看到记录了登陆消息:
继续使用telnet登陆另外的用户之后就可以聊天了:
功能很简陋了,不过这让我想起了二三十年前的事,嘿嘿,那时候应该就是这样子聊天的了吧,生在这个时代的我们永远都体会不到那种乐趣了。
希望本文所述对大家的Python程序设计有所帮助。
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新日志
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]