亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

主頁 > 知識庫 > python實現(xiàn)簡單的聊天小程序

python實現(xiàn)簡單的聊天小程序

熱門標簽:預(yù)覽式外呼系統(tǒng) 企業(yè)彩鈴地圖標注 外賣地址有什么地圖標注 銀川電話機器人電話 如何地圖標注公司 電銷機器人錄音要學(xué)習(xí)什么 長春極信防封電銷卡批發(fā) 上海正規(guī)的外呼系統(tǒng)最新報價 煙臺電話外呼營銷系統(tǒng)

概要

這是一個使用python實現(xiàn)一個簡單的聊天室的功能,里面包含群聊,私聊兩種聊天方式.實現(xiàn)的方式是使用套接字編程的一個使用TCP協(xié)議 c/s結(jié)構(gòu)的聊天室

實現(xiàn)思路

x01 服務(wù)端的建立

首先,在服務(wù)端,使用socket進行消息的接受,每接受一個socket的請求,就開啟一個新的線程來管理消息的分發(fā)與接受,同時,又存在一個handler來管理所有的線程,從而實現(xiàn)對聊天室的各種功能的處理

x02 客戶端的建立

客戶端的建立就要比服務(wù)端簡單多了,客戶端的作用只是對消息的發(fā)送以及接受,以及按照特定的規(guī)則去輸入特定的字符從而實現(xiàn)不同的功能的使用,因此,在客戶端這里,只需要去使用兩個線程,一個是專門用于接受消息,一個是專門用于發(fā)送消息的

至于為什么不用一個呢,那是因為,只用一個的話,當接受了消息,在發(fā)送之前接受消息的處于阻塞狀態(tài),同理,發(fā)送消息也是,那么要是將這兩個功能放在一個地方實現(xiàn),就會導(dǎo)致沒有辦法連續(xù)發(fā)送或者接受消息了

實現(xiàn)方式

服務(wù)端實現(xiàn)

import json
import threading
from socket import *
from time import ctime


class PyChattingServer:
    __socket = socket(AF_INET, SOCK_STREAM, 0)
    __address = ('', 12231)

    __buf = 1024

    def __init__(self):
        self.__socket.bind(self.__address)
        self.__socket.listen(20)
        self.__msg_handler = ChattingHandler()

    def start_session(self):
        print('等待客戶連接...\r\n')
        try:
            while True:
                cs, caddr = self.__socket.accept()
                # 利用handler來管理線程,實現(xiàn)線程之間的socket的相互通信
                self.__msg_handler.start_thread(cs, caddr)
        except socket.error:
            pass


class ChattingThread(threading.Thread):
    __buf = 1024

    def __init__(self, cs, caddr, msg_handler):
        super(ChattingThread, self).__init__()
        self.__cs = cs
        self.__caddr = caddr
        self.__msg_handler = msg_handler

    # 使用多線程管理會話
    def run(self):
        try:
            print('...連接來自于:', self.__caddr)
            data = '歡迎你到來PY_CHATTING!請輸入你的很cooooool的昵稱(不能帶有空格喲`)\r\n'
            self.__cs.sendall(bytes(data, 'utf-8'))
            while True:
                data = self.__cs.recv(self.__buf).decode('utf-8')
                if not data:
                    break
                self.__msg_handler.handle_msg(data, self.__cs)
                print(data)
        except socket.error as e:
            print(e.args)
            pass
        finally:
            self.__msg_handler.close_conn(self.__cs)
            self.__cs.close()


class ChattingHandler:
    __help_str = "[ SYSTEM ]\r\n" \

                 "輸入/ls,即可獲得所有登陸用戶信息\r\n" \

                 "輸入/h,即可獲得幫助\r\n" \

                 "輸入@用戶名 (注意用戶名后面的空格)+消息,即可發(fā)動單聊\r\n" \

                 "輸入/i,即可屏蔽群聊信息\r\n" \

                 "再次輸入/i,即可取消屏蔽\r\n" \

                 "所有首字符為/的信息都不會發(fā)送出去"

    __buf = 1024
    __socket_list = []

    __user_name_to_socket = {}
    __socket_to_user_name = {}

    __user_name_to_broadcast_state = {}

    def start_thread(self, cs, caddr):
        self.__socket_list.append(cs)
        chat_thread = ChattingThread(cs, caddr, self)
        chat_thread.start()

    def close_conn(self, cs):
        if cs not in self.__socket_list:
            return
        # 去除socket的記錄
        nickname = "SOMEONE"
        if cs in self.__socket_list:
            self.__socket_list.remove(cs)
        # 去除socket與username之間的映射關(guān)系
        if cs in self.__socket_to_user_name:
            nickname = self.__socket_to_user_name[cs]
            self.__user_name_to_socket.pop(self.__socket_to_user_name[cs])
            self.__socket_to_user_name.pop(cs)
            self.__user_name_to_broadcast_state.pop(nickname)
        nickname += " "
        # 廣播某玩家退出聊天室
        self.broadcast_system_msg(nickname + "離開了PY_CHATTING")

    # 管理用戶輸入的信息
    def handle_msg(self, msg, cs):
        js = json.loads(msg)
        if js['type'] == "login":
            if js['msg'] not in self.__user_name_to_socket:
                if ' ' in js['msg']:
                    self.send_to(json.dumps({
                        'type': 'login',
                        'success': False,
                        'msg': '賬號不能夠帶有空格'
                    }), cs)
                else:
                    self.__user_name_to_socket[js['msg']] = cs
                    self.__socket_to_user_name[cs] = js['msg']
                    self.__user_name_to_broadcast_state[js['msg']] = True
                    self.send_to(json.dumps({
                        'type': 'login',
                        'success': True,
                        'msg': '昵稱建立成功,輸入/ls可查看所有在線的人,輸入/help可以查看幫助(所有首字符為/的消息都不會發(fā)送)'
                    }), cs)
                    # 廣播其他人,他已經(jīng)進入聊天室
                    self.broadcast_system_msg(js['msg'] + "已經(jīng)進入了聊天室")
            else:
                self.send_to(json.dumps({
                    'type': 'login',
                    'success': False,
                    'msg': '賬號已存在'
                }), cs)
        # 若玩家處于屏蔽模式,則無法發(fā)送群聊消息
        elif js['type'] == "broadcast":
            if self.__user_name_to_broadcast_state[self.__socket_to_user_name[cs]]:
                self.broadcast(js['msg'], cs)
            else:
                self.send_to(json.dumps({
                    'type': 'broadcast',
                    'msg': '屏蔽模式下無法發(fā)送群聊信息'
                }), cs)
        elif js['type'] == "ls":
            self.send_to(json.dumps({
                'type': 'ls',
                'msg': self.get_all_login_user_info()
            }), cs)
        elif js['type'] == "help":
            self.send_to(json.dumps({
                'type': 'help',
                'msg': self.__help_str
            }), cs)
        elif js['type'] == "sendto":
            self.single_chatting(cs, js['nickname'], js['msg'])
        elif js['type'] == "ignore":
            self.exchange_ignore_state(cs)

    def exchange_ignore_state(self, cs):
        if cs in self.__socket_to_user_name:
            state = self.__user_name_to_broadcast_state[self.__socket_to_user_name[cs]]
            if state:
                state = False
            else:
                state = True
            self.__user_name_to_broadcast_state.pop(self.__socket_to_user_name[cs])
            self.__user_name_to_broadcast_state[self.__socket_to_user_name[cs]] = state
            if self.__user_name_to_broadcast_state[self.__socket_to_user_name[cs]]:
                msg = "通常模式"
            else:
                msg = "屏蔽模式"
            self.send_to(json.dumps({
                'type': 'ignore',
                'success': True,
                'msg': '[TIME : %s]\r\n[ SYSTEM ] : %s\r\n' % (ctime(), "模式切換成功,現(xiàn)在是" + msg)
            }), cs)
        else:
            self.send_to({
                'type': 'ignore',
                'success': False,
                'msg': '切換失敗'
            }, cs)

    def single_chatting(self, cs, nickname, msg):
        if nickname in self.__user_name_to_socket:
            msg = '[TIME : %s]\r\n[ %s CHATTING TO %s ] : %s\r\n' % (
                ctime(), self.__socket_to_user_name[cs], nickname, msg)
            self.send_to_list(json.dumps({
                'type': 'single',
                'msg': msg
            }), self.__user_name_to_socket[nickname], cs)
        else:
            self.send_to(json.dumps({
                'type': 'single',
                'msg': '該用戶不存在'
            }), cs)
        print(nickname)

    def send_to_list(self, msg, *cs):
        for i in range(len(cs)):
            self.send_to(msg, cs[i])

    def get_all_login_user_info(self):
        login_list = "[ SYSTEM ] ALIVE USER : \r\n"
        for key in self.__socket_to_user_name:
            login_list += self.__socket_to_user_name[key] + ",\r\n"
        return login_list

    def send_to(self, msg, cs):
        if cs not in self.__socket_list:
            self.__socket_list.append(cs)
        cs.sendall(bytes(msg, 'utf-8'))

    def broadcast_system_msg(self, msg):
        data = '[TIME : %s]\r\n[ SYSTEM ] : %s\r\n' % (ctime(), msg)
        js = json.dumps({
            'type': 'system_msg',
            'msg': data
        })
        # 屏蔽了群聊的玩家也可以獲得系統(tǒng)的群發(fā)信息
        for i in range(len(self.__socket_list)):
            if self.__socket_list[i] in self.__socket_to_user_name:
                self.__socket_list[i].sendall(bytes(js, 'utf-8'))

    def broadcast(self, msg, cs):
        data = '[TIME : %s]\r\n[%s] : %s\r\n' % (ctime(), self.__socket_to_user_name[cs], msg)
        js = json.dumps({
            'type': 'broadcast',
            'msg': data
        })
        # 沒有的登陸的玩家無法得知消息,屏蔽了群聊的玩家也沒辦法獲取信息
        for i in range(len(self.__socket_list)):
            if self.__socket_list[i] in self.__socket_to_user_name \

                    and self.__user_name_to_broadcast_state[self.__socket_to_user_name[self.__socket_list[i]]]:
                self.__socket_list[i].sendall(bytes(js, 'utf-8'))


def main():
    server = PyChattingServer()
    server.start_session()


main()

客戶端的實現(xiàn)

import json
import threading
from socket import *

is_login = False
is_broadcast = True


class ClientReceiveThread(threading.Thread):
    __buf = 1024

    def __init__(self, cs):
        super(ClientReceiveThread, self).__init__()
        self.__cs = cs

    def run(self):
        self.receive_msg()

    def receive_msg(self):
        while True:
            msg = self.__cs.recv(self.__buf).decode('utf-8')
            if not msg:
                break
            js = json.loads(msg)
            if js['type'] == "login":
                if js['success']:
                    global is_login
                    is_login = True
                print(js['msg'])
            elif js['type'] == "ignore":
                if js['success']:
                    global is_broadcast
                    if is_broadcast:
                        is_broadcast = False
                    else:
                        is_broadcast = True
                print(js['msg'])
            else:
                if not is_broadcast:
                    print("[現(xiàn)在處于屏蔽模式]")
                print(js['msg'])


class ClientSendMsgThread(threading.Thread):

    def __init__(self, cs):
        super(ClientSendMsgThread, self).__init__()
        self.__cs = cs

    def run(self):
        self.send_msg()

    # 根據(jù)不同的輸入格式來進行不同的聊天方式
    def send_msg(self):
        while True:
            js = None
            msg = input()
            if not is_login:
                js = json.dumps({
                    'type': 'login',
                    'msg': msg
                })
            elif msg[0] == "@":
                data = msg.split(' ')
                if not data:
                    print("請重新輸入")
                    break
                nickname = data[0]
                nickname = nickname.strip("@")
                if len(data) == 1:
                    data.append(" ")
                js = json.dumps({
                    'type': 'sendto',
                    'nickname': nickname,
                    'msg': data[1]
                })
            elif msg == "/help":
                js = json.dumps({
                    'type': 'help',
                    'msg': None
                })
            elif msg == "/ls":
                js = json.dumps({
                    'type': 'ls',
                    'msg': None
                })
            elif msg == "/i":
                js = json.dumps({
                    'type': 'ignore',
                    'msg': None
                })
            else:
                if msg[0] != '/':
                    js = json.dumps({
                        'type': 'broadcast',
                        'msg': msg
                    })
            if js is not None:
                self.__cs.sendall(bytes(js, 'utf-8'))


def main():
    buf = 1024
    # 改變這個的地址,變成服務(wù)器的地址,那么只要部署到服務(wù)器上就可以全網(wǎng)使用了
    address = ("127.0.0.1", 12231)
    cs = socket(AF_INET, SOCK_STREAM, 0)
    cs.connect(address)
    data = cs.recv(buf).decode("utf-8")
    if data:
        print(data)
    receive_thread = ClientReceiveThread(cs)
    receive_thread.start()
    send_thread = ClientSendMsgThread(cs)
    send_thread.start()
    while True:
        pass


main()

這樣一個簡單的聊天室就建立了。

總結(jié)

在這個實現(xiàn)聊天室當中,我使用的是json格式的字符串信息來編寫的協(xié)議,或許,也可以使用一些更加簡單的方式去實現(xiàn)

其實這個聊天室也就是一個最基本的socket編程的實現(xiàn)方案,也是一些屬于網(wǎng)絡(luò)方面的比較簡單的編寫吧

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • 利用Python實現(xiàn)定時程序的方法
  • 基于Python+Pyqt5開發(fā)一個應(yīng)用程序
  • Python如何實現(xiàn)的簡單購物車程序
  • 結(jié)合Python網(wǎng)絡(luò)爬蟲做一個今日新聞小程序

標簽:佳木斯 上饒 宜昌 盤錦 湖北 西寧 珠海 潮州

巨人網(wǎng)絡(luò)通訊聲明:本文標題《python實現(xiàn)簡單的聊天小程序》,本文關(guān)鍵詞  python,實現(xiàn),簡單,的,聊天,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《python實現(xiàn)簡單的聊天小程序》相關(guān)的同類信息!
  • 本頁收集關(guān)于python實現(xiàn)簡單的聊天小程序的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    成人影视在线观看| 欧美另类videosbestsex久久| 国产精品免费久久| 欧美激情一区二区三区视频 | 国产91素人搭讪系列天堂| 国产不卡在线观看视频| 国产a毛片| 国产麻豆精品视频| 天天做日日干| 日韩男人天堂| 99久久精品费精品国产一区二区| 亚洲 国产精品 日韩| 日韩在线观看免费| 一级毛片看真人在线视频| 日本伦理片网站| 欧美日本韩国| 久久久成人影院| 国产视频一区在线| 国产一区二区福利久久| 国产不卡精品一区二区三区| 一 级 黄 中国色 片| 日韩在线观看视频免费| 日本伦理黄色大片在线观看网站| 美女免费黄网站| 精品国产一区二区三区免费 | 日韩一级黄色| 国产网站免费视频| 日日爽天天| 国产一级强片在线观看| 国产91精品一区| 午夜在线影院| 黄色免费网站在线| 欧美另类videosbestsex高清| 久久久久久久久综合影视网| 国产综合成人观看在线| 免费毛片基地| 国产麻豆精品| 久久99这里只有精品国产| 在线观看成人网| 久久久久久久男人的天堂| 韩国毛片免费大片| 韩国毛片| 999精品影视在线观看| 精品视频一区二区| 日韩中文字幕一区| 久久99中文字幕| 午夜在线亚洲| 亚洲天堂免费| 日日爽天天| 尤物视频网站在线| 精品久久久久久免费影院| 日本伦理片网站| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 日韩一级黄色大片| 久久精品大片| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 九九久久国产精品| 亚洲女初尝黑人巨高清在线观看| 国产网站免费| 在线观看成人网| 日韩欧美一二三区| 国产精品自拍一区| 黄视频网站免费看| 99热视热频这里只有精品| 九九免费精品视频| 欧美激情影院| 国产精品自拍亚洲| 日本免费乱人伦在线观看| 久久国产一区二区| 成人免费网站视频ww| 日韩av东京社区男人的天堂| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 成人高清护士在线播放| 成人在免费观看视频国产| 韩国毛片免费大片| 国产麻豆精品| 99久久精品费精品国产一区二区| 精品久久久久久综合网| 四虎影视库| 日韩av东京社区男人的天堂| 成人在激情在线视频| 精品视频免费观看| 日本在线不卡免费视频一区| 久久久久久久男人的天堂| 日本乱中文字幕系列| 日韩中文字幕在线播放| a级毛片免费观看网站| 久久精品大片| 精品视频在线观看视频免费视频| 精品久久久久久中文| 91麻豆精品国产片在线观看| 毛片高清| 久久国产精品自由自在| 成人av在线播放| 美女免费精品高清毛片在线视| 国产91精品系列在线观看| 国产a免费观看| 久久精品欧美一区二区| 欧美激情一区二区三区在线播放| 999精品影视在线观看| 高清一级做a爱过程不卡视频| 欧美激情一区二区三区在线播放| 日本乱中文字幕系列| 精品国产香蕉在线播出| 久久99中文字幕| 国产91素人搭讪系列天堂| 免费一级生活片| 亚洲精品影院| 国产91精品一区二区| 日本免费乱人伦在线观看 | 午夜激情视频在线观看| 美女免费精品视频在线观看| 亚欧视频在线| 日韩avdvd| 九九九在线视频| 日本免费看视频| 精品视频在线看 | 色综合久久天天综合绕观看| 亚洲www美色| 青青青草影院| 韩国毛片 免费| 日韩avdvd| 精品国产一区二区三区久| 日韩中文字幕在线亚洲一区| 国产成人啪精品| 人人干人人插| 美女免费毛片| 欧美1区| 毛片的网站| 欧美大片aaaa一级毛片| 深夜做爰性大片中文| 色综合久久天天综合绕观看| 91麻豆精品国产自产在线观看一区 | 国产网站麻豆精品视频| 韩国毛片| 精品国产一区二区三区久久久蜜臀| 欧美激情影院| 日韩女人做爰大片| 日本特黄特色aa大片免费| 国产精品自拍一区| 一级女性全黄久久生活片| 天天做日日干| 美国一区二区三区| 亚洲精品中文字幕久久久久久| 成人影视在线播放| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 欧美电影免费| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 日韩在线观看免费完整版视频| 精品视频在线看 | 欧美一级视频免费观看| 国产91素人搭讪系列天堂| 欧美激情一区二区三区视频高清| 黄色免费网站在线| 欧美国产日韩精品| 欧美激情一区二区三区在线| 国产成人精品一区二区视频| 麻豆午夜视频| 天天色色网| 精品在线视频播放| 91麻豆国产| 午夜欧美福利| 亚飞与亚基在线观看| 午夜欧美成人久久久久久| 日韩avdvd| 99热视热频这里只有精品| 国产精品1024永久免费视频| 国产a免费观看| 国产成人精品综合| 在线观看导航| 国产不卡精品一区二区三区| 99久久精品国产高清一区二区 | 久久国产一区二区| 国产伦精品一区三区视频| 中文字幕一区二区三区 精品| 色综合久久天天综合| 成人免费观看视频| 久草免费在线视频| 韩国毛片| 亚洲 欧美 成人日韩| 国产91视频网| 亚洲精品永久一区| 欧美日本韩国| 黄色免费网站在线| 国产视频一区二区在线播放| 日韩在线观看网站| 久久国产一久久高清| 欧美激情一区二区三区视频 | 美女免费毛片| 精品久久久久久综合网| 国产美女在线一区二区三区| 99色视频在线观看| 久久精品欧美一区二区| 一级女性大黄生活片免费| 国产一区二区高清视频| 国产成人精品影视| 免费国产在线观看不卡| 亚洲精品久久久中文字| 国产精品自拍一区|