Files
wechat_ipad_pro/srv/wxrouter/wxheartbeat.go
2026-02-17 13:06:23 +08:00

46 lines
1.3 KiB
Go

package wxrouter
import (
"time"
"xiawan/wx/clientsdk"
"xiawan/wx/protobuf/wechat"
"xiawan/wx/srv/wxcore"
"xiawan/wx/srv/wxface"
"github.com/lunny/log"
)
// WXHeartBeatRouter 心跳包响应路由
type WXHeartBeatRouter struct {
wxcore.WXBaseRouter
}
// Handle 处理conn业务的方法
func (hbr *WXHeartBeatRouter) Handle(wxResp wxface.IWXResponse) error {
defer wxcore.TryE("WXHeartBeatRouter Handle")
currentWXConn := wxResp.GetWXConncet()
currentWXAccount := currentWXConn.GetWXAccount()
currentUserInfo := currentWXAccount.GetUserInfo()
// 解析心跳包响应
var hearBeatResp wechat.HeartBeatResponse
err := clientsdk.ParseResponseData(currentUserInfo, wxResp.GetPackHeader(), &hearBeatResp)
if err != nil {
// 请求出问题了,判断是否掉线,并重连
time.Sleep(1 * time.Second)
go currentWXConn.CheckOnLineStatusLogin()
return err
}
if hearBeatResp.GetBaseResponse().GetRet() == 0 {
log.Printf("[%s],[%s] HeartBeatSuccess \n", currentUserInfo.GetUserName(), currentUserInfo.NickName)
currentWXConn.StopShortReader()
// 获取当前时间 秒
nowTime := time.Now().Unix()
currentWXConn.SetHeartBeatTime(nowTime)
}
//fmt.Println("心跳--->", hearBeatResp.GetBaseResponse().GetRet())
// 等待 NextTime后再次发送心跳包
currentWXConn.SendHeartBeatWaitingSeconds(hearBeatResp.GetNextTime())
return nil
}