zoukankan      html  css  js  c++  java
  • apollo实现c#与android消息推送(四)

    4  Android代码只是为了实现功能,比较简单,就只是贴出来  源码

    package com.myapps.mqtttest;
    
    import java.util.concurrent.Executors;
    import java.util.concurrent.ScheduledExecutorService;
    import java.util.concurrent.TimeUnit;
    
    import org.eclipse.paho.client.mqttv3.IMqttDeliveryToken;
    import org.eclipse.paho.client.mqttv3.MqttCallback;
    import org.eclipse.paho.client.mqttv3.MqttClient;
    import org.eclipse.paho.client.mqttv3.MqttConnectOptions;
    import org.eclipse.paho.client.mqttv3.MqttException;
    import org.eclipse.paho.client.mqttv3.MqttMessage;
    import org.eclipse.paho.client.mqttv3.persist.MemoryPersistence;
    
    import android.app.Activity;
    import android.os.Bundle;
    import android.os.Handler;
    import android.os.Message;
    import android.provider.Settings;
    import android.view.KeyEvent;
    import android.widget.TextView;
    import android.widget.Toast;
    
    public class MainActivity extends Activity {
    
        private TextView resultTv;
        private String mDeviceID;
        private String host = "tcp://192.168.101.195:61613";
        private String userName = "admin";
        private String passWord = "password";
    
        private Handler handler;
    
        private MqttClient client;
    
        private String myTopic = "test";
    
        private MqttConnectOptions options;
    
        private ScheduledExecutorService scheduler;
    
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_main);
            mDeviceID = Settings.Secure.getString(this.getContentResolver(), Settings.Secure.ANDROID_ID);
            resultTv = (TextView) findViewById(R.id.result);
    
            init();
    
            handler = new Handler() {
                @Override
                public void handleMessage(Message msg) {
                    super.handleMessage(msg);
                    if(msg.what == 1) {
                        Toast.makeText(MainActivity.this, (String) msg.obj,
                                Toast.LENGTH_SHORT).show();
                        System.out.println("-----------------------------");
                    } else if(msg.what == 2) {
                        Toast.makeText(MainActivity.this, "连接成功", Toast.LENGTH_SHORT).show();
                        try {
                            client.subscribe(myTopic, 1);
                        } catch (Exception e) {
                            e.printStackTrace();
                        }
                    } else if(msg.what == 3) {
                        Toast.makeText(MainActivity.this, "连接失败,正在重连", Toast.LENGTH_SHORT).show();
                    }
                }
            };
    
            startReconnect();
    
        }
    
        private void startReconnect() {
            scheduler = Executors.newSingleThreadScheduledExecutor();
            scheduler.scheduleAtFixedRate(new Runnable() {
    
                @Override
                public void run() {
                    if(!client.isConnected()) {
                        connect();
                    }
                }
            }, 0 * 1000, 10 * 1000, TimeUnit.MILLISECONDS);
        }
    
        private void init() {
            try {
                //host为主机名,test为clientid即连接MQTT的客户端ID,一般以客户端唯一标识符表示,MemoryPersistence设置clientid的保存形式,默认为以内存保存
                client = new MqttClient(host, "testandroid",
                        new MemoryPersistence());
                //MQTT的连接设置
                options = new MqttConnectOptions();
                //设置是否清空session,这里如果设置为false表示服务器会保留客户端的连接记录,这里设置为true表示每次连接到服务器都以新的身份连接
                options.setCleanSession(true);
                //设置连接的用户名
                options.setUserName(userName);
                //设置连接的密码
                options.setPassword(passWord.toCharArray());
                // 设置超时时间 单位为秒
                options.setConnectionTimeout(10);
                // 设置会话心跳时间 单位为秒 服务器会每隔1.5*20秒的时间向客户端发送个消息判断客户端是否在线,但这个方法并没有重连的机制
                options.setKeepAliveInterval(20);
                //设置回调
                client.setCallback(new MqttCallback() {
    
                    @Override
                    public void connectionLost(Throwable cause) {
                        //连接丢失后,一般在这里面进行重连
                        System.out.println("connectionLost----------");
                    }
    
                    @Override
                    public void deliveryComplete(IMqttDeliveryToken token) {
                        //publish后会执行到这里
                        System.out.println("deliveryComplete---------"
                                + token.isComplete());
                    }
    
                    @Override
                    public void messageArrived(String topicName, MqttMessage message)
                            throws Exception {
                        //subscribe后得到的消息会执行到这里面
                        System.out.println("messageArrived----------");
                        Message msg = new Message();
                        msg.what = 1;
                        msg.obj = topicName+"---"+message.toString();
                        handler.sendMessage(msg);
                    }
                });
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
    
        private void connect() {
            new Thread(new Runnable() {
    
                @Override
                public void run() {
                    try {
                        client.connect(options);
                        Message msg = new Message();
                        msg.what = 2;
                        handler.sendMessage(msg);
                    } catch (Exception e) {
                        e.printStackTrace();
                        Message msg = new Message();
                        msg.what = 3;
                        handler.sendMessage(msg);
                    }
                }
            }).start();
        }
    
        @Override
        public boolean onKeyDown(int keyCode, KeyEvent event) {
            if(client != null && keyCode == KeyEvent.KEYCODE_BACK) {
                try {
                    client.disconnect();
                } catch (Exception e) {
                    e.printStackTrace();
                }
            }
            return super.onKeyDown(keyCode, event);
        }
    
        @Override
        protected void onDestroy() {
            super.onDestroy();
            try {
                scheduler.shutdown();
                client.disconnect();
            } catch (MqttException e) {
                e.printStackTrace();
            }
        }
    }
    View Code

        

  • 相关阅读:
    选择高性能NoSQL数据库的5个步骤
    如何将 Redis 用于微服务通信的事件存储
    让你的AI模型尽可能的靠近数据源
    Collections.sort 给集合排序
    Bootstrap 文件上传插件File Input的使用
    select2 api参数的文档
    textarea 标签换行及靠左
    JSON
    JDK的get请求方式
    通讯录作业
  • 原文地址:https://www.cnblogs.com/xlxr45/p/7625367.html
Copyright © 2011-2022 走看看