瀏覽代碼

fix: split long text messages into multiple parts in wechatmp_service

develop
lanvent 1 年之前
父節點
當前提交
7cefe2d825
共有 2 個文件被更改,包括 6 次插入2 次删除
  1. +1
    -1
      channel/wechatmp/common.py
  2. +5
    -1
      channel/wechatmp/wechatmp_channel.py

+ 1
- 1
channel/wechatmp/common.py 查看文件

@@ -51,7 +51,7 @@ def split_string_by_utf8_length(string, max_length, max_split=0):
if max_split > 0 and len(result) >= max_split:
result.append(encoded[start:].decode("utf-8"))
break
end = start + max_length
end = min(start + max_length, len(encoded))
# 如果当前字节不是 UTF-8 编码的开始字节,则向前查找直到找到开始字节为止
while end < len(encoded) and (encoded[end] & 0b11000000) == 0b10000000:
end -= 1


+ 5
- 1
channel/wechatmp/wechatmp_channel.py 查看文件

@@ -130,7 +130,11 @@ class WechatMPChannel(ChatChannel):
else:
if reply.type == ReplyType.TEXT or reply.type == ReplyType.INFO or reply.type == ReplyType.ERROR:
reply_text = reply.content
self.client.message.send_text(receiver, reply_text)
texts = split_string_by_utf8_length(reply_text, MAX_UTF8_LEN)
if len(texts)>1:
logger.info("[wechatmp] text too long, split into {} parts".format(len(texts)))
for text in texts:
self.client.message.send_text(receiver, text)
logger.info("[wechatmp] Do send text to {}: {}".format(receiver, reply_text))
elif reply.type == ReplyType.VOICE:
try:


Loading…
取消
儲存