Python构建企业微信自动消息转发服务端

举报
技术火炬手 发表于 2018/08/09 10:00:04 2018/08/09
【摘要】 一、背景目前有在项目分组,就小组成员中,微信群消息回复较多的情况下,想根据组来转发特定消息,包含文字、图片、语言等。在此只是自己实现仅供参考,可以根据自身需求修改更多功能。二、代码2.1 企业微信相关信息企业ID:corpid自建应用appid自建应用secret获取access_token api发送消息 api2.2 服务端部署运行环境:python 版本 2.7git clone ht...

一、背景

目前有在项目分组,就小组成员中,微信群消息回复较多的情况下,想根据组来转发特定消息,包含文字、图片、语言等。在此只是自己实现仅供参考,可以根据自身需求修改更多功能。


二、代码

2.1 企业微信相关信息

  • 企业ID:corpid

Python构建企业微信自动消息转发服务端

  • 自建应用appid

  • 自建应用secret

Python构建企业微信自动消息转发服务端

2.2 服务端部署
运行环境:
python 版本 2.7

git clone https://github.com/redhatxl/wechatmsg.git
nohup python2.7 wechatmsg/wx_msg_server.py &

2.3 参考RUL:

获取access_token
发送消息

2.4 代码

# flask 框架后台
  def server_run(self):
        app = Flask(__name__)
        @app.route('/index', methods=['GET', 'POST'])
        def index():

            wxcpt = WXBizMsgCrypt(self.sToken, self.sEncodingAESKey, self.sCorpID)            # 获取url验证时微信发送的相关参数
            sVerifyMsgSig = request.args.get('msg_signature')
            sVerifyTimeStamp = request.args.get('timestamp')
            sVerifyNonce = request.args.get('nonce')
            sVerifyEchoStr = request.args.get('echostr')            # 验证url
            if request.method == 'GET':
                ret, sEchoStr = wxcpt.VerifyURL(sVerifyMsgSig, sVerifyTimeStamp, sVerifyNonce, sVerifyEchoStr)                print type(ret)                print type(sEchoStr)                if (ret != 0):                    print "ERR: VerifyURL ret:" + str(ret)
                    sys.exit(1)                return sEchoStr            # 接收客户端消息
            if request.method == 'POST':
                sReqMsgSig = sVerifyMsgSig
                sReqTimeStamp = sVerifyTimeStamp
                sReqNonce = sVerifyNonce
                sReqData = request.data                print(sReqData)

                ret, sMsg = wxcpt.DecryptMsg(sReqData, sReqMsgSig, sReqTimeStamp, sReqNonce)                print ret, sMsg                if (ret != 0):                    print "ERR: DecryptMsg ret: " + str(ret)
                    sys.exit(1)                # 解析发送的内容并打印

                xml_tree = ET.fromstring(sMsg)                print('xml_tree is ', xml_tree)
  • 消息内容发送

 def _send_text_msg(self, content):
        data = {            "touser": ('|').join(self.userid.split(',')),            "toparty": ('|').join(self.partid.split(',')),            # "toparty":int(self.partid),
            "msgtype": "text",            "agentid": self.agent_id,            "text": {                "content": content
            },            "safe": 0
        }        try:
            response = requests.post(self.send_msg_url.format(self.access_token), json.dumps(data))            self.logoper.info(response.text)            print(response.text)
            result_msg = json.loads(response.content)['errmsg']            return result_msg
        except Exception as e:            self.logoper.info(e)
  • 日志

   def create_dir(self):
        """
        创建目录
        :return: 文件名称
        """
        _LOGDIR = os.path.join(os.path.dirname(__file__), self.logdir_name)
        _TIME = time.strftime('%Y-%m-%d', time.gmtime()) + '-'
        _LOGNAME = _TIME + self.logfile_name
        LOGFILENAME = os.path.join(_LOGDIR, _LOGNAME)        if not os.path.exists(_LOGDIR):
            os.mkdir(_LOGDIR)        return LOGFILENAME    def create_logger(self, logfilename):
        """
        创建logger对象
        :param logfilename:
        :return: logger对象
        """
        logger = logging.getLogger()
        logger.setLevel(logging.INFO)
        handler = logging.FileHandler(logfilename)
        handler.setLevel(logging.INFO)
        formater = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s')
        handler.setFormatter(formater)
        logger.addHandler(handler)        return logger

配置文件

# 定义微信公众号信息[common]# 企业微信企业IDcorpid = wxe23xxxxxxxxxxx# 接收消息服务器配置[recmsg]Token = mVNAAw3xxxxxxxxxxxxxxxxxEncodingAESKey = vwbKImxc3WPeE073xxxxxxxxxxxxxxxxxx# 自建应用信息[appconfig]# 自建应用agentidagentid = 1000002# 自建应用secretsecret = 6HAGX7Muw36pv5anxxxxxxxxxxxxxxxxxxxxxxxxxxxxx# 消息接收信息# 消息接收用户id,如果多个用户用英文','隔开userid = xuel|yaoy# 消息接收部门id,如果多个用英文','隔开partid = 11[urlconfig]# 获取应用token的api接口get_access_token_url = https://qyapi.weixin.qq.com/cgi-bin/gettoken?corpid={}&corpsecret={}# 发送消息api接口send_msg_url = https://qyapi.weixin.qq.com/cgi-bin/message/send?access_token={}# 上传媒体api接口,获取mediaidupload_media_url = https://qyapi.weixin.qq.com/cgi-bin/media/upload?access_token={}&type=image# 上传高清语音接口upload_video_url = https://qyapi.weixin.qq.com/cgi-bin/media/get/jssdk?access_token={}&media_id={}[loginfo]#日志目录logdir_name = logdir#日志文件名称logfile_name = wechat_server.log


三、测试

在企业微信发送消息,可以修改配置文件制定转发到特定的群组,从而避免消息分流。
启用应用API,设置回调地址
Python构建企业微信自动消息转发服务端
Python构建企业微信自动消息转发服务端
测试发送消息
Python构建企业微信自动消息转发服务端
查看接受消息
Python构建企业微信自动消息转发服务端


四、优化

  • 后期可以配合数据库将每次获取的access_token 保存至数据库,待2小时过期后,再重新获取新的。

  • 更多内容转发


本文转自KaliArch博客51CTO博客,如需转载,请自行联系原作者。

原文链接


【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。