安卓使用Kotlin实现mqtt的连接和主题订阅

目录

需要注意的:


这是记录能用代码的,想知道原理的话,可以自行搜索

二话不说,上代码,拷了就能用

package com.doshare.boardroom.control.comm.mqtt

import android.content.Context
import android.util.Log
import androidx.lifecycle.ViewModelProvider
import com.doshare.boardroom.control.comm.retrofit.BoardRoomControlServiceImpl
import com.doshare.boardroom.control.common.device.AppHelper
import com.doshare.boardroom.control.common.device.DeviceIdUtils
import com.doshare.boardroom.control.view.viewmodel.HomeViewModel
import com.google.gson.Gson
import com.google.gson.internal.LinkedTreeMap
import org.eclipse.paho.android.service.MqttAndroidClient
import org.eclipse.paho.client.mqttv3.*


object MqttClient {
    private lateinit var mqttClient: MqttAndroidClient
    // TAG
    private val TAG = "AndroidMqttClient"

    /**
     * 创建连接
     */
    fun connect(context: Context) {
        val serverURI = "tcp://172.17.**.202:1883" //mqtt的服务器地址
        val username = "ds-mqtt"  //用户名
        val password = "do***321"  //密码

        mqttClient = MqttAndroidClient(context, serverURI, "IScreen-"+ DeviceIdUtils.getDeviceId(context))
        mqttClient.setCallback(object : MqttCallback {
            override fun messageArrived(topic: String?, message: MqttMessage?) {
            //这里是对收到mqtt消息进行处理的地方,

                Log.d(TAG, "Receive message: ${message.toString()} from topic: $topic")
                val messageMap = Gson().fromJson(message.toString(),Map::class.java)as                 LinkedTreeMap<String, Any>

            }

            override fun connectionLost(cause: Throwable?) {
                Log.d(TAG, "Connection lost ${cause.toString()}")
            }

            override fun deliveryComplete(token: IMqttDeliveryToken?) {

            }
        })

        // MQTT的连接设置
        val options = MqttConnectOptions()
        options.userName = username
        options.password = password.toCharArray()

        try {
            mqttClient.connect(options, null, object : IMqttActionListener {
                override fun onSuccess(asyncActionToken: IMqttToken?) {
                    Log.d(TAG, "Connection success")
                    subscribe("sunblind/user/+/notify") //订阅主题
                    
                }
                override fun onFailure(asyncActionToken: IMqttToken?, exception: Throwable?) {
                    Log.d(TAG, "Connection failure")
                }
            })
        } catch (e: MqttException) {
            e.printStackTrace()
        }

    }

    /**
     * 订阅主题
     */
    fun subscribe(topic: String, qos: Int = 1) {
        try {
            mqttClient.subscribe(topic, qos, null, object : IMqttActionListener {
                override fun onSuccess(asyncActionToken: IMqttToken?) {
                    Log.d(TAG, "Subscribed to $topic")
                }

                override fun onFailure(asyncActionToken: IMqttToken?, exception: Throwable?) {
                    Log.d(TAG, "Failed to subscribe $topic")
                }
            })
        } catch (e: MqttException) {
            e.printStackTrace()
        }
    }

    /**
     * 取消订阅
     */
    fun unsubscribe(topic: String) {
        try {
            mqttClient.unsubscribe(topic, null, object : IMqttActionListener {
                override fun onSuccess(asyncActionToken: IMqttToken?) {
                    Log.d(TAG, "Unsubscribed to $topic")
                }

                override fun onFailure(asyncActionToken: IMqttToken?, exception: Throwable?) {
                    Log.d(TAG, "Failed to unsubscribe $topic")
                }
            })
        } catch (e: MqttException) {
            e.printStackTrace()
        }
    }

    /**
     * 发布消息
     */
    fun publish(topic: String, msg: String, qos: Int = 1, retained: Boolean = false)  {
        try {
            val message = MqttMessage()
            message.payload = msg.toByteArray()
            message.qos = qos
            message.isRetained = retained
            mqttClient.publish(topic, message, null, object : IMqttActionListener {
                override fun onSuccess(asyncActionToken: IMqttToken?) {
                    Log.d(TAG, "$msg published to $topic")
                }

                override fun onFailure(asyncActionToken: IMqttToken?, exception: Throwable?) {
                    Log.d(TAG, "Failed to publish $msg to $topic")
                }
            })
        } catch (e: Exception) {
            e.printStackTrace()
        }
    }

    /**
     * 取消连接
     */
    fun disconnect() {
        try {
            mqttClient.disconnect(null, object : IMqttActionListener {
                override fun onSuccess(asyncActionToken: IMqttToken?) {
                    Log.d(TAG, "Disconnected")
                }

                override fun onFailure(asyncActionToken: IMqttToken?, exception: Throwable?) {
                    Log.d(TAG, "Failed to disconnect")
                }
            })
        } catch (e: MqttException) {
            e.printStackTrace()
        }
    }
}

需要注意的:

1.connect方法中serverURI //mqtt的服务器地址,username  //用户名,password  //密码这三个数据换成自己的
2.  mqttClient.connect中订阅的主题换成自己的

3.上面import了好多的无用包,直接删掉

4.改包名

  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 4
    评论
Android使用Kotlin搭建MQTT客户端连接订阅和发布接收订阅消息,可以使用Eclipse Paho MQTT库。以下是使用此库的步骤: 1. 添加依赖项 在项目的build.gradle文件中添加以下依赖项: ``` dependencies { implementation "org.eclipse.paho:org.eclipse.paho.client.mqttv3:1.2.5" } ``` 2. 连接MQTT代理 在Kotlin代码中,可以使用以下代码连接MQTT代理: ``` val client = MqttClient(serverURI, clientId) val options = MqttConnectOptions() options.userName = username options.password = password.toCharArray() client.connect(options) ``` 其中,`serverURI`是MQTT代理的URI,`clientId`是客户端ID,`username`和`password`是连接到代理所需的凭据。 3. 订阅消息 使用以下代码订阅一个主题: ``` val topic = "example/topic" client.subscribe(topic) ``` 4. 接收消息 为了接收消息,需要实现MqttCallback接口并注册为客户端的回调。例如: ``` class MyMqttCallback : MqttCallback { override fun connectionLost(cause: Throwable?) { // 连接丢失时的处理 } override fun messageArrived(topic: String?, message: MqttMessage?) { // 收到消息时的处理 } override fun deliveryComplete(token: IMqttDeliveryToken?) { // 消息传递完成时的处理 } } client.setCallback(MyMqttCallback()) ``` 5. 发布消息 使用以下代码发布一个消息: ``` val topic = "example/topic" val message = "Hello, MQTT!" client.publish(topic, message.toByteArray(), 0, false) ``` 其中,`topic`是要发布消息的主题,`message`是要发布的消息内容。 这是一个基本的使用Eclipse Paho MQTT库在Android使用Kotlin搭建MQTT客户端连接订阅和发布接收订阅消息的示例。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小趴菜8227

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值