#开源项目#wechat-go 微信机器人/web 协议

2017-04-21 13:34:41 +08:00
 spice630

wechat-go

https://github.com/songtianyi/wechat-go

go 版本 wechat web api , 十分欢迎 gopher 参与开发更多有趣实用的插件。同时求一个前端,写两个页面给普通用户使用。

Install

go get -u -v github.com/songtianyi/wechat-go

golang.org/x dep install

mkdir $GOPATH/src/golang.org/x
cd $GOPATH/src/golang.org/x
git clone https://github.com/golang/net.git
git clone https://github.com/golang/text.git

Demo project

go-aida

Example code

Create your own chatbot
package main

import (
	"github.com/songtianyi/rrframework/logs"
	"github.com/songtianyi/wechat-go/plugins/faceplusplus"
	"github.com/songtianyi/wechat-go/wxweb"
	"github.com/songtianyi/wechat-go/plugins/wxweb/gifer"
	"github.com/songtianyi/wechat-go/plugins/wxweb/replier"
	"github.com/songtianyi/wechat-go/plugins/wxweb/switcher"
)

func main() {
	// create session
	session, err := wxweb.CreateSession(nil, nil, wxweb.TERMINAL_MODE)
	if err != nil {
		logs.Error(err)
		return
	}

	// add plugins for this session, they are disabled by default
	faceplusplus.Register(session)
	replier.Register(session)
	switcher.Register(session)
	gifer.Register(session)

	// enable plugin
	session.HandlerRegister.EnableByName("switcher")
	session.HandlerRegister.EnableByName("faceplusplus")

	if err := session.LoginAndServe(); err != nil {
		logs.Error("session exit, %s", err)
	}
}

Plugins

switcher

一个管理插件的插件

#关闭某个插件, 在微信聊天窗口输入
disable faceplusplus
#开启某个插件, 在微信聊天窗口输入
enable faceplusplus
#查看所有插件信息, 在微信聊天窗口输入
dump
faceplusplus

对收到的图片做面部识别,返回性别和年龄

gifer

以收到的文字消息为关键字做 gif 搜索,返回 gif 图, 注意返回的 gif 可能尺度较大,比如文字消息中包含“污”等关键词。

replier

对收到的文字 /图片消息,做自动应答,回复固定文字消息

laosj

随机获取一张美女图片, 在聊天窗口输入

美女
joker

获取一则笑话, 在聊天窗口输入

笑话
revoker

消息撤回插件, 3s 后自动撤回手机端所发的文本消息. 机器人发出的消息需要自己在插件里写撤回逻辑.

制作自己插件

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")

	// 可以多个个消息类型使用同一个处理函数,也可以分开
	session.HandlerRegister.Add(wxweb.MSG_IMG, wxweb.Handler(demo), "imgdemo")
}

// 消息处理函数
func demo(session *wxweb.Session, msg *wxweb.ReceivedMessage) {

	// 可选:避免此插件对所有群 /联系人生效 可以用 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

}

Show

13217 次点击
所在节点    分享创造
94 条回复
only0jac
2017-05-22 10:48:28 +08:00
试了一下,一小时内必掉线,且无法自动登录,楼主有这种情况吗?
spice630
2017-05-22 19:31:02 +08:00
@only0jac
贴下错误信息看下呢?
only0jac
2017-05-22 21:56:34 +08:00
only0jac
2017-05-22 22:33:24 +08:00
@spice630 还有,不是说可以自动登陆么?
spice630
2017-05-23 09:52:09 +08:00
@only0jac
需要自己加这个逻辑
```
for {
if err := session.LoginAndServe(false); err != nil {
logs.Error("session exit, %s", err)
for i := 0; i < 3; i++ {
logs.Info("trying re-login with cache")
if err := session.LoginAndServe(true); err != nil {
logs.Error("re-login error, %s", err)
}
time.Sleep(3 * time.Second)
}
if session, err = wxweb.CreateSession(nil, session.HandlerRegister, wxweb.TERMINAL_MODE); err != nil {
logs.Error("create new sesion failed, %s", err)
break
}
} else {
logs.Info("closed by user")
break
}
}
```

我抽空在 windows 测试下
spice630
2017-05-23 09:55:50 +08:00
@only0jac
代码有点乱,参考 travis/bot.go
only0jac
2017-05-23 13:30:23 +08:00
@spice630 谢谢,刚发现一个 bug,挂了有五六个小时,前一段时间正常,最后虽然后台显示没掉线,但已经收不到消息了,并且登陆手机微信也没显示网页在线
only0jac
2017-05-23 13:33:03 +08:00
@spice630 最后状态是 1102
spice630
2017-05-23 15:03:12 +08:00
@only0jac
1102 没有做处理, 之前并没有遇到过这个值。拉下最新的代码,已经把所有的异常 ret 都当错误抛出去了,这样会进入重登逻辑。
目前还不清楚 1102 的意思。
挂机期间 网络有波动不?
spice630
2017-05-23 15:06:01 +08:00
@only0jac
另外,你的截图里 有个%s,能贴下代码不,应该不是示例代码吧。
only0jac
2017-05-23 18:21:36 +08:00
@spice630 vps 挂机,国内 Windows 阿里云和国外 centos 都试过,无网络波动,在线不会超过半天,必掉线,截图的%s,是我把你的 logs 替换成了 fmt.println,不过我又换回来了,用的你原先的代码,然后错误却不输出了
only0jac
2017-05-23 19:10:38 +08:00
@spice630

这个是编译最新的 bot.go,一发消息就挂

spice630
2017-05-23 21:03:10 +08:00
@only0jac
go 版本
spice630
2017-05-23 21:03:55 +08:00
@only0jac
方便的话提个 issue,便于跟踪问题,也有利于其他遇到相同问题的人:)
spice630
2017-05-23 21:41:29 +08:00
@only0jac
刚在 windows 下跑了下,问题确实多,尽快解决。
only0jac
2017-05-23 23:02:10 +08:00
@spice630 go 是最新版本,linux 下也没法用,老掉线
spice630
2017-05-23 23:40:28 +08:00
@only0jac
目前还没 时间做 稳定性方面的优化 :( , 你可以用 web 版挂机试下 可以挂多久。
leopku
2017-05-24 01:58:17 +08:00
之前星了,支持一下
spice630
2017-05-24 09:33:14 +08:00
@leopku
感谢🙏,
spice630
2017-05-24 22:44:02 +08:00
@only0jac
windows 端的,请在 mac 或者 linux 下使用交叉编译。
GOOS=windows GOARCH=amd64 go build travis/windows/windows_bot.go
二维码在 ../public/qrcode 下

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/356399

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX