企业微信个人账号直连自动化 基于 Wechaty 框架连接企业微信个人账号,实现完整的 AI 助手功能。适用于企业微信机器人、自动化客服、个人助手等场景。 核心功能 1. 自动同意好友添加 监听好友请求事件 自动通过好友验证 发送个性化欢迎消息 标注用户信息和来源 2. 智能问答(基于知识库) 向量知识库存储企业知识 语义搜索匹配问题 LLM 生成专业回复 支持多轮对话上下文 3. 人工介入提醒 置信度阈值自动判断 通过 Telegram/飞书通知人工 记录未解决问题用于优化 平滑转接到人工客服 4. 消息类型支持 文本消息(问答、对话) 图片消息(OCR、识别) 文件消息(DOCX、PDF 等) 语音消息(转文字、语音交互) 链接消息(预览、摘要) 名片消息(保存、处理) 技术架构 ┌──────────────┐ │ 企业微信 │ │ 个人账号 │ └──────┬───────┘ │ ▼ ┌──────────────────┐ │ Wechaty │ │ (PadLocal) │ └──────┬───────────┘ │ ▼ ┌────────────────────┐ │ OpenClaw Gateway │ │ (消息分发、处理) │ └──────┬─────────────┘ │ ├──────────────┬──────────────┐ │ │ │ ▼ ▼ ▼ ┌──────────┐ ┌──────────┐ ┌──────────┐ │ 向量知识库 │ │ LLM API │ │ 通知服务 │ │(PG+pgvec)│ │ (Kimi/GPT)│ │(Telegram)│ └──────────┘ └──────────┘ └──────────┘ 快速开始 方案选择 企业微信个人账号直连有两种方案: 方案 A:Wechaty + PadLocal(推荐,适合个人) 优点 : 配置简单,快速上手 稳定性高,官方维护 支持所有消息类型 适合个人使用 缺点 : PadLocal 需要付费(约 50 元/月) 单账号限制 适用场景 :个人助手、小规模客服 方案 B:企业微信内部应用 API(适合企业) 优点 : 官方 API,免费使用 稳定性最高 支持大规模部署 缺点 : 需要企业认证 配置相对复杂 功能受限于 API 适用场景 :企业客服、大规模应用 本技能使用方案 A(Wechaty + PadLocal) 第一步:申请 PadLocal Token 访问 https://github.com/wechaty/wechaty 选择 "PadLocal" 协议 注册账号并获取 Token 保存 Token 到 pass: pass insert api/wechaty-padlocal 第二步:安装依赖
1. 安装 Node.js 依赖
cd ~/clawd/skills/wecom-automation npm install
2. 安装 Python 依赖
pip3 install -r requirements.txt
3. 配置环境变量
cp .env.example .env 第三步:配置环境变量 编辑 ~/clawd/skills/wecom-automation/.env :
Wechaty 配置
WECHATY_PUPPET=padlocal WECHATY_TOKEN=$(pass show api/wechaty-padlocal) WECHATY_LOG_LEVEL=info
企业微信账号配置
WECOM_NAME="企业微信机器人" WECOM_QR_CODE_PATH=/tmp/wecom_qrcode.png
知识库配置
KB_DB_URL=postgresql://postgres@localhost/wecom_kb KB_SIMILARITY_THRESHOLD=0.7 KB_TOP_K=3
LLM 配置
LLM_PROVIDER=kimi LLM_API_KEY=$(pass show api/kimi) LLM_API_BASE=https://api.moonshot.cn/v1 LLM_MODEL=moonshot-v1-8k
人工介入通知
NOTIFICATION_CHANNEL=telegram:8518085684 NOTIFICATION_ENABLED=true
OpenClaw Gateway 配置
GATEWAY_URL=http://localhost:8080 GATEWAY_TOKEN=$(pass show api/openclaw-gateway) 第四步:初始化数据库
创建数据库
sudo -u postgres createdb wecom_kb
初始化表结构
psql wecom_kb < ~/clawd/skills/wecom-automation/schema.sql
导入示例知识库
python3 ~/clawd/skills/wecom-automation/scripts/import_kb.py \ --input ~/clawd/skills/wecom-automation/knowledge/sample.md \ --category "常见问题" \ --key " $( pass show api/kimi ) " 第五步:启动机器人
方式 1:直接运行
cd ~/clawd/skills/wecom-automation npm start
方式 2:通过 PM2(推荐)
pm2 start ~/clawd/skills/wecom-automation/ecosystem.config.js
查看日志
pm2 logs wecom-bot
第六步:扫码登录
启动机器人后会显示二维码:
██████████████████████████████████
██ ██
██ 1. 打开企业微信 → 扫一扫 ██
██ 2. 扫描下方二维码登录 ██
██ ██
██████████████████████████████████
[二维码图片]
使用企业微信扫码登录后,机器人即可正常工作。
使用方法
场景 1:新好友自动欢迎
// workflows/on_friend_add.js
const
{
Contact
}
=
require
(
'wechaty'
)
bot
.
on
(
'friendship'
,
async
friendship
=>
{
if
(
friendship
.
type
(
)
===
Friendship
.
Type
.
Receive
)
{
const
contact
=
friendship
.
contact
(
)
// 自动通过好友请求
await
friendship
.
accept
(
)
// 发送欢迎消息
await
contact
.
say
(
👋 欢迎来到
${
contact
.
name
(
)
}
!
我是智能助手小a,可以帮您:
• 解答常见问题
• 处理售后请求
• 查询订单状态
如有复杂问题,我会转接人工客服为您服务。
)
// 添加到数据库
await
saveUser
(
contact
)
}
}
)
场景 2:知识库问答
// workflows/answer_question.js
const
{
Message
}
=
require
(
'wechaty'
)
bot
.
on
(
'message'
,
async
msg
=>
{
if
(
msg
.
type
(
)
===
Message
.
Type
.
Text
)
{
const
text
=
msg
.
text
(
)
const
from
=
msg
.
from
(
)
// 搜索知识库
const
results
=
await
searchKnowledge
(
text
)
// 生成答案
const
answer
=
await
generateAnswer
(
text
,
results
)
// 判断是否需要人工介入
if
(
answer
.
confidence
<
0.7
)
{
await
escalateToHuman
(
from
,
text
,
answer
)
}
else
{
await
msg
.
say
(
answer
.
text
)
}
}
}
)
场景 3:文件处理(DOCX/PDF)
// workflows/handle_file.js
const
{
Message
}
=
require
(
'wechaty'
)
bot
.
on
(
'message'
,
async
msg
=>
{
if
(
msg
.
type
(
)
===
Message
.
Type
.
Attachment
)
{
const
file
=
await
msg
.
toFileBox
(
)
// 下载文件
const
filePath
=
/tmp/
${
file
.
name
}
await
file
.
toFile
(
filePath
)
// 处理文件(提取内容、分析等)
const
content
=
await
extractFileContent
(
filePath
)
// 发送回复
await
msg
.
say
(
✅ 已收到文件:
${
file
.
name
}
\n\n正在处理...
)
// 处理后回复
await
processAndReply
(
msg
,
content
)
}
}
)
场景 4:人工介入提醒
// workflows/escalate.js
async
function
escalateToHuman
(
contact
,
question
,
answer
)
{
// 1. 发送用户消息
await
contact
.
say
(
'⏳ 已为您转接人工客服,请稍候...'
)
// 2. 通过 Telegram 通知人工客服
const
notification
=
🚨 需要人工介入
用户:
${
contact
.
name
(
)
}
问题:
${
question
}
时间:
${
new
Date
(
)
.
toLocaleString
(
)
}
请及时处理。
await
sendTelegramNotification
(
notification
)
// 3. 记录未解决问题
await
saveUnknownQuestion
(
contact
,
question
)
}
目录结构
~/clawd/skills/wecom-automation/
├── SKILL.md # 本文件
├── package.json # Node.js 依赖
├── requirements.txt # Python 依赖
├── ecosystem.config.js # PM2 配置
├── .env.example # 环境变量模板
├── schema.sql # 数据库表结构
├── bot.js # Wechaty 机器人主文件
├── config/
│ ├── knowledge.js # 知识库配置
│ └── escalation.js # 人工介入规则
├── workflows/
│ ├── on_friend_add.js # 好友添加处理
│ ├── answer_question.js # 问答处理
│ ├── handle_file.js # 文件处理
│ └── escalate.js # 人工介入
├── lib/
│ ├── knowledge.js # 知识库操作
│ ├── llm.js # LLM 调用
│ ├── notification.js # 通知服务
│ └── database.js # 数据库操作
└── knowledge/
└── sample.md # 示例知识文档
API 参考文档
企业微信 API 文档
企业微信 API 总览
消息发送
成员管理
Wechaty 文档
Wechaty 官方文档
PadLocal 协议
消息类型
Kimi API 文档
Kimi API 总览
Embedding API
Chat API
高级功能
1. 多轮对话记忆
// 使用 Redis 存储会话上下文
const
redis
=
require
(
'redis'
)
const
client
=
redis
.
createClient
(
)
async
function
getConversationHistory
(
userId
)
{
const
history
=
await
client
.
get
(
conv:
${
userId
}
)
return
history
?
JSON
.
parse
(
history
)
:
[
]
}
async
function
appendMessage
(
userId
,
role
,
content
)
{
const
history
=
await
getConversationHistory
(
userId
)
history
.
push
(
{
role
,
content
,
timestamp
:
Date
.
now
(
)
}
)
await
client
.
set
(
conv:
${
userId
}
,
JSON
.
stringify
(
history
)
)
}
2. 文件处理
// 提取 DOCX 内容
const
docx
=
require
(
'docx'
)
async
function
extractDocx
(
filePath
)
{
const
doc
=
await
docx
.
Document
.
read
(
filePath
)
const
text
=
doc
.
paragraphs
.
map
(
p
=>
p
.
text
)
.
join
(
'\n'
)
return
text
}
// 提取 PDF 内容
const
pdf
=
require
(
'pdf-parse'
)
async
function
extractPdf
(
filePath
)
{
const
data
=
await
fs
.
readFile
(
filePath
)
const
result
=
await
pdf
(
data
)
return
result
.
text
}
3. 语音转文字
使用 Whisper API
import openai def transcribe_audio ( audio_path ) : with open ( audio_path , "rb" ) as audio : transcript = openai . Audio . transcribe ( model = "whisper-1" , file = audio ) return transcript [ "text" ] 4. 图片 OCR
使用 Kimi Vision
import openai def ocr_image ( image_path ) : with open ( image_path , "rb" ) as image : result = openai . chat . completions . create ( model = "gemini-2.5-pro" , messages = [ { "role" : "user" , "content" : "识别图片中的文字" } ] , image = image ) return result . choices [ 0 ] . message . content 监控与维护 日志查看
PM2 日志
pm2 logs wecom-bot
错误日志
pm2 logs wecom-bot --err
实时日志
pm2 logs wecom-bot --lines 100 性能监控 // 添加自定义指标 const prometheus = require ( 'prom-client' ) const messageCounter = new prometheus . Counter ( { name : 'wecom_messages_total' , help : 'Total messages received' , labelNames : [ 'type' ] } ) const answerLatency = new prometheus . Histogram ( { name : 'wecom_answer_latency_seconds' , help : 'Answer generation latency' , buckets : [ 0.1 , 0.5 , 1 , 2 , 5 , 10 ] } ) 人工介入统计 -- 查看未解决问题分布 SELECT COUNT ( * ) as count , SUBSTRING ( question , 1 , 30 ) as question_preview FROM unknown_questions GROUP BY question_preview ORDER BY count DESC LIMIT 10 ; -- 查看每日介入次数 SELECT DATE ( created_at ) as date , COUNT ( * ) as escalations FROM escalation_log GROUP BY DATE ( created_at ) ORDER BY date DESC LIMIT 7 ; 故障排查 问题 1:无法扫码登录
检查 Wechaty 日志
pm2 logs wecom-bot --lines 50
重启机器人
pm2 restart wecom-bot
清理缓存
rm -rf /tmp/wechaty* pm2 restart wecom-bot 问题 2:消息不回复
检查知识库连接
psql wecom_kb -c "SELECT COUNT(*) FROM knowledge_chunks;"
测试 LLM API
curl -X POST https://api.moonshot.cn/v1/chat/completions \ -H "Authorization: Bearer $KIMI_API_KEY " \ -H "Content-Type: application/json" \ -d '{"model":"moonshot-v1-8k","messages":[{"role":"user","content":"测试"}]}'
检查环境变量
cat ~/clawd/skills/wecom-automation/.env | grep -E "^(LLM|KB|NOTIFICATION)" 问题 3:文件无法接收
检查临时目录权限
ls -la /tmp/
创建日志目录
mkdir -p ~/clawd/skills/wecom-automation/logs chmod 755 ~/clawd/skills/wecom-automation/logs
检查磁盘空间
- df
- -h
- 安全最佳实践
- 密钥管理
- 所有密钥使用
- pass
- 存储
- 环境变量引用,不硬编码
- 定期轮换 Token
- 数据隐私
- 客户信息加密存储
- 定期清理敏感日志
- 遵守数据保护法规
- 访问控制
- API 接口鉴权
- IP 白名单限制
- 请求频率限制
- 审计日志
- 记录所有人工介入
- 定期审查访问日志
- 异常行为告警
- 扩展功能
- 1. 主动营销
- // 定期推送优惠信息
- const
- schedule
- =
- require
- (
- 'node-schedule'
- )
- schedule
- .
- scheduleJob
- (
- '0 10 * * 1-5'
- ,
- async
- (
- )
- =>
- {
- const
- users
- =
- await
- getActiveUsers
- (
- 7
- )
- for
- (
- const
- user
- of
- users
- )
- {
- await
- user
- .
- say
- (
- '🎉 今日特惠:...'
- )
- }
- }
- )
- 2. 群组管理
- // 自动邀请用户加入群组
- bot
- .
- on
- (
- 'friendship'
- ,
- async
- friendship
- =>
- {
- const
- contact
- =
- friendship
- .
- contact
- (
- )
- const
- room
- =
- await
- bot
- .
- Room
- .
- find
- (
- {
- topic
- :
- '客户群'
- }
- )
- if
- (
- room
- )
- {
- await
- room
- .
- add
- (
- contact
- )
- await
- contact
- .
- say
- (
- '已邀请您加入客户群'
- )
- }
- }
- )
- 3. 数据统计
- // 每日生成报表
- async
- function
- generateDailyReport
- (
- )
- {
- const
- stats
- =
- {
- newUsers
- :
- await
- countNewUsers
- (
- )
- ,
- questions
- :
- await
- countQuestions
- (
- )
- ,
- escalations
- :
- await
- countEscalations
- (
- )
- }
- await
- sendReportToAdmin
- (
- stats
- )
- }
- 相关技能
- wecom-cs-automation
-
- 企业微信客服 API 方式
- feishu-automation
-
- 飞书平台自动化
- notion-automation
-
- Notion 知识库集成
- telegram-automation
- Telegram 通知集成 成本对比 方案 月成本 适用场景 Wechaty + PadLocal ~50元 个人、小团队 企业微信内部应用 免费 企业、大规模 企业微信客服 API 按量 企业客服 参考资源 Wechaty GitHub PadLocal 官网 企业微信开发者中心 PostgreSQL pgvector