bl双性强迫侵犯h_国产在线观看人成激情视频_蜜芽188_被诱拐的少孩全彩啪啪漫画

基于python實現聊天室程序-創新互聯

本文實例為大家分享了python實現簡單聊天室的具體代碼,供大家參考,具體內容如下

為葉縣等地區用戶提供了全套網頁設計制作服務,及葉縣網站建設行業解決方案。主營業務為網站制作、成都網站制作、葉縣網站設計,以傳統方式定制建設網站,并提供域名空間備案等一條龍服務,秉承以專業、用心的態度為用戶提供真誠的服務。我們深信只要達到每一位用戶的要求,就會得到認可,從而選擇與我們長期合作。這樣,我們也可以走得更遠!

剛剛接觸python編程,又從接觸java開始一直對socket模塊感興趣,所以就做了一個聊天室的小程序。

該程序由客戶端與服務器構成,使用UDP服務,服務器端綁定本地IP和端口,客戶端由系統隨機選擇端口。

實現了群發、私發、點對點文件互傳功能。

客戶端自建了一個類繼承了Cmd模塊,使用自定義的命令command進行操作,調用相應的do_command方法。

使用json模塊進行消息的封裝序列化,在接收方進行解析。

客戶端代碼如下:

import socket
import threading
import json
import os
from cmd import Cmd
 
 
class Client(Cmd):
 """
 客戶端
 """
 prompt = '>>>'
 intro = '[Welcome] 簡易聊天室客戶端(Cli版)\n' + '[Welcome] 輸入help來獲取幫助\n'
 buffersize = 1024
 
 def __init__(self, host):
  """
  構造
  """
  super().__init__()
  self.__socket = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
  # self.__id = None
  self.__nickname = None
  self.__host = host
  self.thread_recv = None
  self.threadisalive = False
  # 是否在接收文件
  self.recvfile = False
  # 是否在發送文件
  self.sendfile = False
  self.filesize = None
  self.sendfilesize = None
 
  # 接收文件包計數
  self.filecount = None
  # 接收文件名
  self.filename = None
  # 發送文件名
  self.sendfilename = None
 
  # 發送者
  self.filefrom = None
  # 接收者
  self.fileto = None
 
  # 接收文件流
  self.file_recv = None
  # 發送文件流
  self.file_send = None
 
  # 接收文件地址
  self.filefrom_addr = None
  # 發送文件地址
  self.fileto_addr = None
 
 def __receive_message_thread(self):
  """
  接受消息線程
  """
  while self.threadisalive:
   # noinspection PyBroadException
   try:
    buffer, addr = self.__socket.recvfrom(1024)
    '''
    文件流由發送端直接發送,不經過服務器,故當發送端發來的消息時,將收到的數據存入文件
    '''
    if (addr != self.__host) & (addr == self.filefrom_addr) & self.recvfile:
     self.file_recv.write(buffer)
     self.filecount += 1
     if self.filecount * 1024 >= self.filesize:
      self.file_recv.close()
      print(self.filename, 'is received.')
      self.recvfile = False
     continue
 
    js = json.loads(buffer.decode())
 
    # 若接收的數據為消息信息,則顯示
    if js['type'] == 'message':
     print(js['message'])
 
    # 若接收的數據為文件發送請求,則存儲文件信息,并顯示
    elif js['type'] == 'filequest':
     if self.recvfile:
      self.__socket.sendto(json.dumps({
       'type': 'fileres',
       'fileres': 'no',
       'nickname': self.__nickname,
       'who': js['nickname'],
       'errormessage': 'is transfroming files.',
      }).encode(), self.__host)
      continue
     filename = js['filename']
     who = js['nickname']
     filesize = js['filesize']
     self.recvfile = True
     self.filesize = filesize
     self.filename = filename
     self.filecount = 0
     self.filefrom = who
     self.filefrom_addr = (js['send_ip'], js['send_port'])
 
     print('[system]:', who, ' send a file(',
       filename, ') to you. receive? ')
 
    # 接受的數據為請求回復,若同意接收則存儲服務器發來的接收方的地址,并開啟發送線程
    elif js['type'] == 'fileres':
     if js['fileres'] == 'yes':
      print(js['recv_ip'], js['recv_port'])
      self.fileto_addr = (js['recv_ip'], js['recv_port'])
      thread = threading.Thread(
       target=self.__send_file_thread)
      thread.start()
     else:
      print(js['nickname'], js['errormessage'])
      self.sendfile = False
 
   except Exception as e:
    print(e)
    print('[Client] 無法從服務器獲取數據')
 
 def __send_broadcast_message_thread(self, message):
  """
  發送廣播消息線程
  :param message: 消息內容
  """
  self.__socket.sendto(json.dumps({
   'type': 'broadcast',
   'nickname': self.__nickname,
   'message': message,
  }).encode(), self.__host)
 
 def __send_file_thread(self):
  """
  發送文件線程
  :param message: 消息內容
  """
  filecount = 0
  print('[system]', 'sending the file...')
  while filecount * 1024 <= self.sendfilesize:
   self.__socket.sendto(
    self.file_send.read(1024), self.fileto_addr)
   filecount += 1
  self.file_send.close()
  self.sendfile = False
  print('[system]', 'the file is sended.')
 
 def __send_whisper_message_thread(self, who, message):
  """
  發送私發消息線程
  :param message: 消息內容
  """
  self.__socket.sendto(json.dumps({
   'type': 'sendto',
   'who': who,
   'nickname': self.__nickname,
   'message': message
  }).encode(), self.__host)
 
 def send_exit(self):
  self.__socket.sendto(json.dumps({
   'type': 'offline',
   'nickname': self.__nickname,
  }).encode(), self.__host)
 
 
 def start(self):
  """
  啟動客戶端
  """
  self.cmdloop()
 
 def do_login(self, args):
  """
  登錄聊天室
  :param args: 參數
  """
  nickname = args.split(' ')[0]
 
  # 將昵稱發送給服務器,獲取用戶id
  self.__socket.sendto(json.dumps({
   'type': 'login',
   'nickname': nickname,
  }).encode(), self.__host)
  # 嘗試接受數據
 
  buffer = self.__socket.recvfrom(1300)[0].decode()
  obj = json.loads(buffer)
  if obj['login'] == 'success':
   self.__nickname = nickname
   print('[Client] 成功登錄到聊天室')
   self.threadisalive = True
   # 開啟子線程用于接受數據
   self.thread_recv = threading.Thread(
    target=self.__receive_message_thread)
   self.thread_recv.setDaemon(True)
   self.thread_recv.start()
  else:
   print('[Client] 無法登錄到聊天室', obj['errormessage'])
 
 def do_send(self, args):
  """
  發送消息
  :param args: 參數
  """
  if self.__nickname is None:
   print('請先登錄!login nickname')
   return
  message = args
  # 開啟子線程用于發送數據
  thread = threading.Thread(
   target=self.__send_broadcast_message_thread, args=(message, ))
  thread.setDaemon(True)
  thread.start()
 
 def do_sendto(self, args):
  """
  發送私發消息
  :param args: 參數
  """
  if self.__nickname is None:
   print('請先登錄!login nickname')
   return
  who = args.split(' ')[0]
  message = args.split(' ')[1]
  # # 顯示自己發送的消息
  # print('[' + str(self.__nickname) + '(' + str(self.__id) + ')' + ']', message)
  # 開啟子線程用于發送數據
  thread = threading.Thread(
   target=self.__send_whisper_message_thread, args=(who, message))
  thread.setDaemon(True)
  thread.start()
 
 def do_catusers(self, arg):
  if self.__nickname is None:
   print('請先登錄!login nickname')
   return
  catmessage = json.dumps({'type': 'catusers'})
  self.__socket.sendto(catmessage.encode(), self.__host)
 
 def do_catip(self, args):
  if self.__nickname is None:
   print('請先登錄!login nickname')
   return
  who = args
  catipmessage = json.dumps({'type': 'catip', 'who': who})
  self.__socket.sendto(catipmessage.encode(), self.__host)
 
 def do_help(self, arg):
  """
  幫助
  :param arg: 參數
  """
  command = arg.split(' ')[0]
  if command == '':
   print('[Help] login nickname - 登錄到聊天室,nickname是你選擇的昵稱')
   print('[Help] send message - 發送消息,message是你輸入的消息')
   print('[Help] sendto who message - 私發消息,who是用戶名,message是你輸入的消息')
   print('[Help] catusers - 查看所有用戶')
   print('[Help] catip who - 查看用戶IP,who為用戶名')
   print('[Help] sendfile who filedir - 向某用戶發送文件,who為用戶名,filedir為文件路徑')
   print('[Help] getfile filename who yes/no - 接收文件,filename 為文件名,who為發送者,yes/no為是否接收')
  elif command == 'login':
   print('[Help] login nickname - 登錄到聊天室,nickname是你選擇的昵稱')
  elif command == 'send':
   print('[Help] send message - 發送消息,message是你輸入的消息')
  elif command == 'sendto':
   print('[Help] sendto who message - 發送私發消息,message是你輸入的消息')
  else:
   print('[Help] 沒有查詢到你想要了解的指令')
 
 def do_exit(self, arg): # 以do_*開頭為命令
  print("Exit")
  self.send_exit()
  try:
   self.threadisalive = False
   self.thread_recv.join()
  except Exception as e:
   print(e)
  # self.__socket.close()
 
 def do_sendfile(self, args):
  who = args.split(' ')[0]
  filepath = args.split(' ')[1]
  filename = filepath.split('\\')[-1]
  # 判斷是否在發送文件
  if self.sendfile:
   print('you are sending files, please try later.')
   return
  if not os.path.exists(filepath):
   print('the file is not exist.')
   return
  filesize = os.path.getsize(filepath)
  # print(who, filename, filesize)
 
  self.sendfile = True
  self.fileto = who
  self.sendfilename = filename
  self.sendfilesize = filesize
  self.file_send = open(filepath, 'rb')
 
  self.__socket.sendto(json.dumps({
   'type': 'filequest',
   'nickname': self.__nickname,
   'filename': self.sendfilename,
   'filesize': self.sendfilesize,
   'who': self.fileto,
   'send_ip': '',
   'send_port': '',
  }).encode(), self.__host)
 
  print('request send...')
 
  # fileres = self.__socket.recvfrom(1024)[0].decode()
  # js = json.loads(fileres)
 
 def do_getfile(self, args):
  filename = args.split(' ')[0]
  who = args.split(' ')[1]
  ch = args.split(' ')[2]
  # print(self.filename is not None, filename, self.filename, who, self.filefrom)
  if (self.filename is not None) & (filename == self.filename) & (who == self.filefrom):
   if ch == 'yes':
    self.file_recv = open(self.filename, 'wb')
    self.__socket.sendto(json.dumps({
     'type': 'fileres',
     'fileres': 'yes',
     'nickname': self.__nickname,
     'who': who,
     'recv_ip': '',
     'recv_port': '',
    }).encode(), self.__host)
    print('you agree to reveive the file(', filename, ') from', who)
 
   else:
    self.__socket.sendto(json.dumps({
     'type': 'fileres',
     'fileres': 'no',
     'nickname': self.__nickname,
     'errormessage': 'deny the file.',
     'who': who,
     'recv_ip': '',
     'recv_port': '',
    }).encode(), self.__host)
    print('you deny to reveive the file(', filename, ') from', who)
    self.recvfile = False
  else:
   print('the name or sender of the file is wrong.')
 
 
c = Client(('127.0.0.1', 12346))
c.start()

分享文章:基于python實現聊天室程序-創新互聯
本文URL:http://vcdvsql.cn/article22/pgjjc.html

成都網站建設公司_創新互聯,為您提供App設計品牌網站設計定制網站ChatGPTApp開發搜索引擎優化

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

搜索引擎優化