最近,需要在手机上连接mqtt微消息服务,按照文档,连接发现一直报
已断开连接 (32109) - java.io.EOFException
W/System.err: at org.eclipse.paho.client.mqttv3.internal.CommsReceiver.run(CommsReceiver.java:146)
W/System.err: at java.lang.Thread.run(Thread.java:784)
W/System.err: Caused by: java.io.EOFException
W/System.err: at java.io.DataInputStream.readByte(DataInputStream.java:270)
W/System.err: at org.eclipse.paho.client.mqttv3.internal.wire.MqttInputStream.readMqttWireMessage(MqttInputStream.java:65)
at org.eclipse.paho.client.mqttv3.internal.CommsReceiver.run(CommsReceiver.java:107)
这样的错误,多方查资料,发现很多资料指向这个错误,说是clientId重复.但是已经在程序里进行了clientId防重复的逻辑,没有办法,只能试.
于是使用mqtt.fx进行测试,发现使用现有的参数,是可以正常连接的,这就百思不得其解了.所幸,在github上找到了相关的示例,使用参数发现也是可以连接的,于是便开始了找两者的不同.最后定位到了在Base64密码上有区别,连接异常代码用了 Base64.DEFAULT,连接正常则是使用了 Base64.NO_WRAP,查了下资料,原来NO_WRAP是去除掉了换行符,这就明白了原来先前连接密码一直是发送了带换行符的密码,这要是能连接上就有鬼了....
破案了,却想不到是这个原因.
参考资料:Android中Base64编码_曾博文的博客-CSDN博客_base64.no_wrapblog.csdn.net