# EasyMqttAndroidClient **Repository Path**: zhanglei459/EasyMqttAndroidClient ## Basic Information - **Project Name**: EasyMqttAndroidClient - **Description**: No description available - **Primary Language**: Unknown - **License**: Not specified - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 1 - **Created**: 2020-02-17 - **Last Updated**: 2022-08-31 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README # EasyMqttAndroidClient 使Mqtt安卓客户端变的更简单、更好用 ## 简介 基于第三方开源框架Mqtt Android客户端封装的用于接收、发布推送消息的组件。 ## 功能 1.支持消息的订阅与发布
2.支持服务器的连接与断开
3.支持连接状态的判断
4.支持自动重连、清除session、心跳间隔、超时时间等配置 ## 使用方法 ### 第一步:在project的build.gradle 文件中添加JitPack依赖 allprojects { repositories { ... maven { url 'https://jitpack.io' } } } ### 第二步: 在Module的build.gradle文件中添加对本库的依赖 dependencies { ... compile 'com.github.ZS-ZhangsShun:EasyMqttAndroidClient:1.0.4' } ### 第三步:开始使用(6.0及以上版本需要在代码中动态申请Manifest.permission.READ_PHONE_STATE权限 参考示例代码) 以下方法可直接拷贝到项目中使用 参数根据实际情况修改即可 详情参考demo中 MainActivity的示例代码 #### (1)构建MqttService对象 /** * 构建EasyMqttService对象 */ private void buildEasyMqttService() { mqttService = new EasyMqttService.Builder() //设置自动重连 .autoReconnect(true) //设置不清除回话session 可收到服务器之前发出的推送消息 .cleanSession(false) //唯一标示 保证每个设备都唯一就可以 建议 imei .clientId("your clientId") //mqtt服务器地址 格式例如:tcp://10.0.261.159:1883 .serverUrl("your mqtt servier url") //心跳包默认的发送间隔 .keepAliveInterval(20) //构建出EasyMqttService 建议用application的context .bulid(this.getApplicationContext()); } #### (2)连接Mqtt服务器 /** * 连接Mqtt服务器 */ private void connect() { mqttService.connect(new IEasyMqttCallBack() { @Override public void messageArrived(String topic, String message, int qos) { //推送消息到达 } @Override public void connectionLost(Throwable arg0) { //连接断开 } @Override public void deliveryComplete(IMqttDeliveryToken arg0) { } @Override public void connectSuccess(IMqttToken arg0) { //连接成功 //建议在这里执行订阅逻辑 //如果cleanSession设置为false的话,不用每次启动app都订阅,第一次订阅后 后面只执行连接操作即可 } @Override public void connectFailed(IMqttToken arg0, Throwable arg1) { //连接失败 } }); } #### (3)订阅主题 /** * 订阅主题 这里订阅三个主题分别是"a", "b", "c" */ private void subscribe() { String[] topics = new String[]{"a", "b", "c"}; //主题对应的推送策略 分别是0, 1, 2 建议服务端和客户端配置的主题一致 // 0 表示只会发送一次推送消息 收到不收到都不关心 // 1 保证能收到消息,但不一定只收到一条 // 2 保证收到切只能收到一条消息 int[] qoss = new int[]{0, 1, 2}; mqttService.subscribe(topics, qoss); } #### (4)关闭连接 /** * 关闭连接 */ private void close() { mqttService.close(); } #### (5)断开连接 /** * 断开连接 */ private void disconnect() { mqttService.disconnect(); } #### (6)判断连接状态 /** * 判断服务是否连接 */ private boolean isConnected() { return mqttService.isConnected(); } #### (7)发布消息 /** * 发布消息 */ private void publish(String msg, String topic, int qos, boolean retained) { mqttService.publish(msg, topic, qos, retained); } #### (8)解除订阅 /** * 解除订阅 */ private void unsubscribe(String[] topics) { mqttService.unsubscribe(topics); } #### (9)获取MqttClient 如果提供的方法不够 可以自己获取client 自定义扩展方法 /** * 获取MqttClient */ private MqttAndroidClient getMqttClient() { mqttService.getMqttClient(); }