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 }