makcar/app/src/main/java/com/aros/apron/callback/MqttActionCallBack.java

84 lines
3.2 KiB
Java
Raw Normal View History

2026-01-30 11:47:32 +08:00
package com.aros.apron.callback;
import android.os.Handler;
2026-05-20 10:15:41 +08:00
import android.os.Looper;
2026-01-30 11:47:32 +08:00
import com.aros.apron.constant.AMSConfig;
import com.aros.apron.tools.LogUtil;
import com.aros.apron.tools.ToastUtil;
import org.eclipse.paho.android.service.MqttAndroidClient;
import org.eclipse.paho.client.mqttv3.IMqttActionListener;
import org.eclipse.paho.client.mqttv3.IMqttToken;
import org.eclipse.paho.client.mqttv3.MqttConnectOptions;
import org.eclipse.paho.client.mqttv3.MqttException;
public class MqttActionCallBack implements IMqttActionListener {
private final String TAG = "MqttActionCallBack";
private MqttAndroidClient mqttAndroidClient;
private MqttConnectOptions options;
2026-05-20 10:15:41 +08:00
private int reconnectAttempt = 0;
private static final int INITIAL_RETRY_INTERVAL = 3000; // 初始重试间隔 3 秒
private static final int MAX_RETRY_INTERVAL = 30000; // 最大重试间隔 30 秒
private static final Handler retryHandler = new Handler(Looper.getMainLooper());
private Runnable retryRunnable;
2026-01-30 11:47:32 +08:00
public MqttActionCallBack(MqttAndroidClient mqttAndroidClient, MqttConnectOptions options) {
this.mqttAndroidClient = mqttAndroidClient;
this.options = options;
}
@Override
public void onSuccess(IMqttToken asyncActionToken) {
LogUtil.log(TAG, "MQtt连接成功-------");
2026-05-20 10:15:41 +08:00
reconnectAttempt = 0;
if (retryRunnable != null) {
retryHandler.removeCallbacks(retryRunnable);
retryRunnable = null;
}
new Handler(Looper.getMainLooper()).post(() -> ToastUtil.showToast("MQtt连接成功"));
2026-01-30 11:47:32 +08:00
try {
2026-05-20 10:15:41 +08:00
mqttAndroidClient.subscribe(AMSConfig.DOWN_UAV_SERVICES, 1);
2026-01-30 11:47:32 +08:00
} catch (MqttException e) {
e.printStackTrace();
}
}
@Override
public void onFailure(IMqttToken asyncActionToken, Throwable exception) {
LogUtil.log(TAG, "MQtt连接失败:" + exception.toString());
try {
2026-05-20 10:15:41 +08:00
if (!mqttAndroidClient.isConnected()) {
reconnectAttempt++;
// 指数退避3s → 6s → 12s → 24s → 30s(封顶)
long retryDelay = Math.min(INITIAL_RETRY_INTERVAL * (1L << Math.min(reconnectAttempt, 4)), MAX_RETRY_INTERVAL);
if (reconnectAttempt % 10 == 0 || reconnectAttempt <= 3) {
LogUtil.log(TAG, "" + reconnectAttempt + " 次重连,间隔 " + retryDelay + "ms");
}
if (retryRunnable != null) {
retryHandler.removeCallbacks(retryRunnable);
}
final long finalDelay = retryDelay;
retryRunnable = new Runnable() {
2026-01-30 11:47:32 +08:00
@Override
public void run() {
try {
2026-05-20 10:15:41 +08:00
mqttAndroidClient.connect(options, null, MqttActionCallBack.this);
2026-01-30 11:47:32 +08:00
} catch (MqttException e) {
2026-05-20 10:15:41 +08:00
LogUtil.log(TAG, "mqtt重连异常:" + e.toString());
2026-01-30 11:47:32 +08:00
}
}
2026-05-20 10:15:41 +08:00
};
retryHandler.postDelayed(retryRunnable, finalDelay);
2026-01-30 11:47:32 +08:00
}
} catch (Exception e) {
e.printStackTrace();
}
}
}