企业微信内部应用开发——聊天机器人消息推送、企业成员消息推送


一、获取access_token

下列获取access_token的方法中

参数必须说明
wechat_corpid企业id
wechat_corpsecret应用id

access_token可参考官网文档:点击跳转

def wechat_token():
    """获取access_token"""
    # 此处我将wechat_corpid以及wechat_corpsecret存放在了数据库的表中
    obj = Profile.objects.filter(name='wechat').first() 
    url = 'https://qyapi.weixin.qq.com/cgi-bin/gettoken?corpid={0}&corpsecret={1}'.format(
        obj.configuration.get('wechat_corpid'), obj.configuration.get('wechat_corpsecret'))
    try:
        req = requests.get(url=url, verify=False)
        token = req.json().get('access_token')
        if token:
        	# token后续发送企业微信消息给成员是需要,agentid为企业应用的id
            return {'status': 'success', 'token': token, 'agentid': obj.configuration.get('wechat_agentid')}
        else:
            return {'status': 'error', 'msg': str(json.loads(req.text))}
    except Exception as e:
        return {'status': 'error', 'msg': str(e)}

二、向企业微信群机器人发送消息

企业微信机器人收到消息后会发送在群里
webhook是企业微信群机器人的webhook地址,需要配置才能使用
以下代码为发送markdown消息,其他类型消息请参考官方文档
企业微信群机器人推送消息官方文档

class WechatSend(object):
    
    def send_webhook_message(self, webhook, content):
	    data = {
	        "msgtype": "markdown",
	        "markdown": {
	            "content": content # content内容支持多种类型
	        }
	    }
	    headers = {'content-type': 'application/json'}
        response = requests.post(webhook, json.dumps(data), headers=headers)
	    info_logger.info("企业微信机器人消息推送 "+str(responses)) # 此处我获取到的响应被放入到了日志文件中
	    return responses

三、向企业微信成员推送消息

发送消息具体信息可查看:
消息推送官方文档

class WechatSend(object):
	    def send_message(self, content, touser):
        # 获取Token,此处引用了本文上方的access_token
        ret = wechat_token()
        if ret.get('status') == 'success':
            agentid = ret.get('agentid')
            headers = {'Content-Type': 'application/json;charset=utf-8'}
            send_url = 'https://qyapi.weixin.qq.com/cgi-bin/message/send?access_token=' + ret.get('token')
            json_text = {
                'touser': touser, # 此处发送消息有三种:指定接收消息的成员、指定接收消息的部门、指定接收消息的标签
                'agentid': agentid,
                "msgtype": "markdown", # 消息类型有多种可参考官方文档
                "markdown": {
                    "content": content
                },
                "safe": 0
            }
            res = requests.post(send_url, json.dumps(json_text, ensure_ascii=False).encode('utf-8'),headers=headers).content
            ret = json.loads(str(res, 'utf-8'))
            if ret['errmsg'] == 'ok':
            	# 成功后将消息存到日志
                info_logger.info("微信成员消息推送成功 msg:" + str(ret["errmsg"]))
                return {'status': 'success'}
            else:
            	# 失败后将消息存到日志
                error_logger.error("微信成员消息推送失败 msg:" + str(ret["errmsg"]))
                return {'status': 'error', 'msg': ret['errmsg']}
        else:
            return {'status': 'error', 'msg': ret.get('msg')}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当然可以!以下是使用C#编写企业微信机器人消息推送的示例代码: ```csharp using System; using System.Net.Http; using System.Text; using System.Threading.Tasks; class Program { static async Task Main(string[] args) { string webhookUrl = "https://qyapi.weixin.qq.com/cgi-bin/webhook/send?key=YOUR_WEBHOOK_KEY"; string message = "这是一条来自企业微信机器人消息推送!"; await SendWebhookMessage(webhookUrl, message); } static async Task SendWebhookMessage(string webhookUrl, string message) { try { using (HttpClient client = new HttpClient()) { var content = new StringContent($"{{\"msgtype\":\"text\",\"text\":{{\"content\":\"{message}\"}}}}", Encoding.UTF8, "application/json"); HttpResponseMessage response = await client.PostAsync(webhookUrl, content); if (response.IsSuccessStatusCode) { Console.WriteLine("消息推送成功!"); } else { Console.WriteLine("消息推送失败!"); } } } catch (Exception ex) { Console.WriteLine("发生异常:" + ex.Message); } } } ``` 请将`YOUR_WEBHOOK_KEY`替换为您在企业微信中创建机器人时生成的Webhook地址的密钥部分。然后,您可以使用`message`变量来设置要发送的消息内容。 这段代码使用`HttpClient`类来发送HTTP POST请求到企业微信机器人的Webhook地址,并将消息以JSON格式进行封装。如果消息推送成功,将输出"消息推送成功!";否则,将输出"消息推送失败!"。注意,您需要确保您的程序可以访问互联网以发送请求。 希望这可以帮助到您!如果您有任何其他问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值