La implementación de GO de la API de la versión web de WeChat simula las funciones de envío y recepción de mensajes de inicio de sesión/mensaje de la versión web de WeChat. Puede hacerse cargo de los mensajes recibidos por WeChat y personalizar su propio contenido de envío.
mkdir -p $GOPATH/src/golang.org/x
cd $GOPATH/src/golang.org/x
git clone https://github.com/golang/net.git
go get -u -v github.com/songtianyi/wechat-go
cd $GOPATH/src/github.com/songtianyi/wechat-go
go get ./...
go build examples/linux/terminal_bot.go
./terminal_bot
La versión de Windows debe generarse utilizando la compilación cruzada en los sistemas que no son de Windows, y luego se ejecuta en Windows tras generación.
GOOS=windows GOARCH=amd64 go build examples/windows/windows_bot.go
./windows_bot.exe
扫码图片需要用软件打开,路径在输出日志内.
aida
package main
import (
"github.com/songtianyi/rrframework/logs"
"github.com/songtianyi/wechat-go/plugins/wxweb/faceplusplus"
"github.com/songtianyi/wechat-go/plugins/wxweb/gifer"
"github.com/songtianyi/wechat-go/plugins/wxweb/replier"
"github.com/songtianyi/wechat-go/plugins/wxweb/switcher"
"github.com/songtianyi/wechat-go/wxweb"
)
func main () {
// 创建session, 一个session对应一个机器人
// 二维码显示在终端上
session , err := wxweb . CreateSession ( nil , nil , wxweb . TERMINAL_MODE )
if err != nil {
logs . Error ( err )
return
}
// 注册插件, 所有插件默认是开启的
faceplusplus . Register ( session )
replier . Register ( session )
switcher . Register ( session )
gifer . Register ( session )
// 你也可以自己选择关闭插件里的handler(消息处理器)
session . HandlerRegister . DisableByName ( "faceplusplus" )
// 登录并接收消息
if err := session . LoginAndServe ( false ); err != nil {
logs . Error ( "session exit, %s" , err )
}
}Un complemento para administrar complementos
#关闭某个插件, 在微信聊天窗口输入
disable faceplusplus
#开启某个插件, 在微信聊天窗口输入
enable faceplusplus
#查看所有插件信息, 在微信聊天窗口输入
dump
Reconocimiento facial para las imágenes recibidas, el género de regreso y la edad
Use los mensajes de texto recibidos como palabras clave para buscar GIF y devolver el gráfico GIF. Tenga en cuenta que el GIF devuelto puede tener una gran escala, como los mensajes de texto contienen palabras clave como "contaminada".
Responda automáticamente a los mensajes de texto/imagen recibidos y responda a mensajes de texto corregidos
Obtén al azar una hermosa imagen e ingrese en la ventana de chat
美女
Consigue una broma e ingresa en la ventana de chat
笑话
El complemento de retiro de mensajes y los mensajes de texto enviados por el teléfono móvil se retirarán automáticamente después de 3 segundos. Los mensajes enviados por el robot deben escribir la lógica de retiro en el complemento correspondiente.
Solicitudes del sistema para procesar los mensajes de retiro/sobres rojos, etc.
Para reenviar mensajes entre grupos, simplemente modifique la ortografía completa del nombre del grupo en el complemento.
Complemento de traducción chino-inglés, basado en la API de traducción de Yodao
Acepte automáticamente las solicitudes de amistad y se puede filtrar de acuerdo con las condiciones
Ejemplo de distribución automática de recursos (Casa de tarjetas)
Configuración de complemento de administración de configuración, ingrese en la ventana de chat
set config key value
Verifique la configuración e ingrese en la ventana de chat
get config key
Uso de la configuración en el código
import "github.com/songtianyi/wechat-go/kv"
func demo () {
kv . KVStorageInstance . Set ( "key" , "value" )
v := kv . KVStorageInstance . Get ( "key" )
if v == nil {
return
}
// v.(string) etc.
}Dos principios de complementos personalizados
Ejemplo de complemento
package demo // 以插件名命令包名
import (
"github.com/songtianyi/rrframework/logs" // 导入日志包
"github.com/songtianyi/wechat-go/wxweb" // 导入协议包
)
// 必须有的插件注册函数
// 指定session, 可以对不同用户注册不同插件
func Register ( session * wxweb. Session ) {
// 将插件注册到session
// 第一个参数: 指定消息类型, 所有该类型的消息都会被转发到此插件
// 第二个参数: 指定消息处理函数, 消息会进入此函数
// 第三个参数: 自定义插件名,不能重名,switcher插件会用到此名称
session . HandlerRegister . Add ( wxweb . MSG_TEXT , wxweb . Handler ( demo ), "textdemo" )
// 开启插件
if err := session . HandlerRegister . EnableByName ( "textdemo" ); err != nil {
logs . Error ( err )
}
}
// 消息处理函数
func demo ( session * wxweb. Session , msg * wxweb. ReceivedMessage ) {
// 可选: 可以用contact manager来过滤, 比如过滤掉没有保存到通讯录的群
// 注意,contact manager只存储了已保存到通讯录的群组
contact := session . Cm . GetContactByUserName ( msg . FromUserName )
if contact == nil {
logs . Error ( "ignore the messages from" , msg . FromUserName )
return
}
// 可选: 根据消息类型来过滤
if msg . MsgType == wxweb . MSG_IMG {
return
}
// 可选: 根据wxweb.User数据结构中的数据来过滤
if contact . PYQuanPin != "songtianyi" {
// 比如根据用户昵称的拼音全拼来过滤
return
}
// 可选: 过滤和自己无关的群组消息
if msg . IsGroup && msg . Who != session . Bot . UserName {
return
}
// 取出收到的内容
// 取text
logs . Info ( msg . Content )
//// 取img
//if b, err := session.GetImg(msg.MsgId); err == nil {
// logs.Debug(string(b))
//}
// anything
// 回复消息
// 第一个参数: 回复的内容
// 第二个参数: 机器人ID
// 第三个参数: 联系人/群组/特殊账号ID
session . SendText ( "plugin demo" , session . Bot . UserName , wxweb . RealTargetUserName ( session , msg ))
// 回复图片和gif 参见wxweb/session.go
}