首页 > 小程序运营

多行业、全场景小程序商城开发

助力企业低成本、精准、高效引流!
将滑块拖动到最右边 x

python搭建微信小程序

2020-01-16 11:06:44|移动云商城|阅读量:

  微信官方发布小程序自动化测试框架Minium。该框架支持使用Python或者Javascript编写自动化测试程序,可以运行在IDE、Android以及iOS三端。

  由于是微信官方发布,该框架注定秒杀现有一切第三方自动化测试框架。该框架支持多种内核运行(X5\原生Webview)以模拟小程序的实际使用场景;可以直接触发小程序上的事件,甚至可以直接调用部分wx.开头的接口;支持直接向AppService注入代码。

  查看文档仍需配置nodejs环境,这一点对Python程序员来说还不够友好。实际上使用该框架并不需要nodejs环境,依旧是Python程序员们熟悉的pip install ... 但是不知为何该项目文档要求运行nodejs环境才能查看。为此,我们把项目文档上传到了github,以便Python程序员可以不必安装nodejs,直接查看项目文档。

  python实现简单的聊天小程序

  服务端实现

  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来管理线程,实现线程之间的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" \

  "输入@用户名 (注意用户名后面的空格)+消息,即可发动单聊\r\n" \

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

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

  "所有首字符为/的信息都不会发送出去"

  __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之间的映射关系

  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可以查看帮助(所有首字符为/的消息都不会发送)'

  }), cs)

  # 广播其他人,他已经进入聊天室

  self.broadcast_system_msg(js['msg'] + "已经进入了聊天室")

  else:

  self.send_to(json.dumps({

  'type': 'login',

  'success': False,

  'msg': '账号已存在'

  }), cs)

  # 若玩家处于屏蔽模式,则无法发送群聊消息

  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': '屏蔽模式下无法发送群聊信息'

  }), 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(), "模式切换成功,现在是" + 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

  })

  # 屏蔽了群聊的玩家也可以获得系统的群发信息

  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()

  客户端的实现

  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("[现在处于屏蔽模式]")

  print(js['msg'])

  class ClientSendMsgThread(threading.Thread):

  def __init__(self, cs):

  super(ClientSendMsgThread, self).__init__()

  self.__cs = cs

  def run(self):

  self.send_msg()

  # 根据不同的输入格式来进行不同的聊天方式

  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

  # 改变这个的地址,变成服务器的地址,那么只要部署到服务器上就可以全网使用了

  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()

相关推荐

  • 如何在微信上做小程序卖菜?有哪些操作

    手机微信做为受人热烈欢迎的沟通交流专用工具之一,也是有很多好用的外卖送餐、买票小程序。现阶段,微信公众平台又发…

  • 如何制作微信公众号?按这个来就行

    微信已经是各个商家争夺的流量市场,无论是哪个领域的商家,都想要在这里分一杯羹。而获取用户的第一步就是建立自己的…

  • 教你分辨门店小程序和小程序:掌握这三种不同

    在小程序开发之前,微信还有一款门店小程序能够使用,这也就让商家在后期想要开发应用时就有了疑惑,这两个程序有什么…

  • 微信小程序免费开店的方式有哪些?

    说起微信小程序商城,相信大家最常接触的开发方式就是定制开发和商城系统开发了,这些开发方式帮助商家更好的搭建自己…

  • 微信订外卖小程序怎么做?制作步骤分享

    外卖的消费模式,已经逐渐成为年轻消费者的主流选择,这种方式在方便用户的购买时,也让商家拥有了新的发展可能,部分…

  • 京东微选平台招商入驻申请入口在哪里?

    移动云商城了解到,京东美丽联合成立的公司,近期对外发布了第一个战略电商产品:微选平台,提出了微信好店大全的品牌…

  • 返回列表

    本文经授权 由移动云商城发布,转载联系作者并注明出处
    《免责声明》如对文章、图片、字体等版权有疑问,请联系我们 。

    首页 获取报价 咨询电话 立即体验