package service import ( "errors" "fmt" "time" "encoding/json" "zhaoCaiMao/vo" mqtt "github.com/eclipse/paho.mqtt.golang" "github.com/gogf/gf/v2/frame/g" "github.com/gogf/gf/v2/util/guid" ) type MQTT struct { client mqtt.Client } var MQTTService MQTT func (t *MQTT) InitMQTT() error { ip := g.Cfg().MustGet(nil, "MQTT.ip") //订单MQTT port := g.Cfg().MustGet(nil, "MQTT.port") /* user := g.Cfg().MustGet(nil, "MQTT.user") passwd := g.Cfg().MustGet(nil, "MQTT.passwd") */ opts := mqtt.NewClientOptions() mqttAddress := fmt.Sprintf("mqtt://%s:%d", ip.String(), port.Int()) g.Log().Line().Print(nil, "订单MQTT连接地址:", mqttAddress) opts.AddBroker(mqttAddress) opts.SetKeepAlive(time.Hour * 24) opts.SetPingTimeout(time.Second * 30) opts.SetClientID(guid.S()) //opts.SetUsername(user.String()) //使用用户名和密码 //opts.SetPassword(passwd.String()) opts.SetDefaultPublishHandler(t.reciveOrderMQTTHandler) // 设置消息回调处理函数 //opts.OnConnect = connectHandler opts.OnConnectionLost = t.connectLostHandler t.client = mqtt.NewClient(opts) token := t.client.Connect() if token.Wait() && token.Error() != nil { err := errors.New("订单MQTT初始化失败:" + token.Error().Error()) g.Log().Line().Error(nil, err) return err } payTopic := g.Cfg().MustGet(nil, "MQTT.topic").String() //订阅支付订单消息 token = t.client.Subscribe(payTopic, 2, nil) if !token.Wait() { return token.Error() } return nil } func (t *MQTT) reciveOrderMQTTHandler(client mqtt.Client, msg mqtt.Message) { logMsg := fmt.Sprintf("Received message: %s from topic: %s\n", msg.Payload(), msg.Topic()) fmt.Println(logMsg) g.Log().Line().Print(nil, logMsg) mqttOrder := vo.MQTTOrder{} err := json.Unmarshal(msg.Payload(),&mqttOrder) if err != nil { g.Log().Line().Print(nil, err) return } t.createMsgToCat(&mqttOrder) //to-----发送到招财猫设备 } func (t *MQTT) connectLostHandler(client mqtt.Client, err error) { token := t.client.Connect() g.Log().Line().Print(nil, "订单MQTT 重新连接成功") token.Wait() } //组织发送招财猫的报文 func (t *MQTT) createMsgToCat(mqttOrder *vo.MQTTOrder) { mqttOrder. mqttDevice := vo.MQTTDevice{} mqttDevice.msgId = mqttOrder.msgId if mqttOrder.Channel == 1 { //微信渠道 mqttdevice.Type = 1 }else { //支付宝渠道 mqttdevice.Type = 2 } }