在企业微信 RPA 开发中,最核心的能力就是"主动发消息"。简单的模拟点击(Click)和模拟按键(SendKeys)极易受到用户干扰或输入法窗口截断。为了实现工业级的稳定性,我们通常采用 Windows 消息注入(Message Injection) 方案,即直接与窗口的消息循环通信。
1. 句柄精确定位:寻找消息接收载体
企微的聊天输入框并不是标准的 Edit 控件,它通常是一个基于 RichEdit 或自绘框架的深度嵌套容器。
-
探测逻辑 :首先利用
FindWindowEx获取主窗口句柄,再通过 UI Automation 找到类型为Edit或Document且IsKeyboardFocusable为True的元素。 -
句柄获取 :通过
NativeWindowHandle属性将 UI 元素转换为可以被 Windows API 操作的HWND。
2. 文本注入:底层 WM_SETTEXT 与剪贴板平衡
直接发送字符串到窗口有多种方式,每种方式都有其适用场景:
-
WM_SETTEXT注入 :这是最直接的方式,通过发送SendMessage强制修改目标控件的文本缓冲区。优点是瞬时完成,不经过输入法。 -
剪贴板 +
WM_PASTE:对于包含表情或复杂富文本的消息,先将内容存入系统剪贴板,再向输入框句柄发送WM_PASTE(0x0302) 消息。这种方式能最大程度模拟人工粘贴行为。
3. 触发发送:模拟 WM_KEYDOWN 回车指令
文本填入输入框后,必须触发"发送"动作。
-
按键序列注入 :通过
PostMessage发送VK_RETURN(Enter 键) 的WM_KEYDOWN和WM_KEYUP组合。 -
避坑点 :如果直接调用
Click发送按钮,若按钮被输入法候选框遮挡,会导致点击失效。而发送消息(Message)是逻辑层的,不受视觉遮挡影响。
4. 关键代码逻辑实现(C# / C++ 逻辑)
cpp
// 1. 找到输入框句柄
HWND hInputEdit = FindWindowEx(hChatWin, NULL, L"RichEditComponent", NULL);
// 2. 注入文本 (以粘贴方式为例)
OpenClipboard(NULL);
EmptyClipboard();
SetClipboardData(CF_UNICODETEXT, hData);
CloseClipboard();
SendMessage(hInputEdit, WM_PASTE, 0, 0);
// 3. 异步发送回车键,确保不阻塞 RPA 主线程
PostMessage(hInputEdit, WM_KEYDOWN, VK_RETURN, 0);
PostMessage(hInputEdit, WM_KEYUP, VK_RETURN, 0);
5. "双重注入"的优势
-
抗干扰性:即使用户在 RPA 执行期间移动鼠标或切换窗口,只要句柄(HWND)有效,消息依然能精准送达输入框。
-
无感执行:不需要将企微窗口强制置顶(Topmost),可以在窗口被其他程序部分遮挡的情况下完成发送任务。
-
时延可控:相比于模拟人工一个字符一个字符地敲击,消息注入是毫秒级的,极大提升了多群轮询发送的效率。
实施建议:客户联系功能启用步骤
操作步骤
- 权限申请
请通过 QiWe开放平台管理后台,提交"客户联系"功能的使用权限申请。
获取访问凭证
请使用企业 corpidcor pid (企业ID)和 corpsecretcorpsecret (应用密钥)作为参数,调用相应接口以获取 access_tokenaccess _token (访问令牌)