如何解决使用Eclipse Paho的MqttAsyncClient连接本地EMQX时用户名密码认证失败的问题?(户名.如何解决.时用.失败.连接...)

wufei1232025-03-24java3

如何解决使用eclipse paho的mqttasyncclient连接本地emqx时用户名密码认证失败的问题?

Eclipse Paho MQTTAsyncClient连接本地EMQX用户名密码认证失败的解决方法

本文档阐述了使用Java和Eclipse Paho的MQTTAsyncClient库连接本地EMQX MQTT Broker时,用户名密码认证失败问题的解决方法。

问题描述

在使用org.eclipse.paho.client.mqttv3库连接本地EMQX(配置为内置数据库密码认证,密码加密方式为plain,加盐禁用)时,即使用户名“emqx_test”和密码“emqx_test_password”正确,连接仍会失败,并抛出MqttSecurityException: 错误的用户名或密码异常。 MQTTX客户端测试连接成功。 Java代码如下:

String brokerUrl = "tcp://127.0.0.1:1883";
MqttAsyncClient mqttClient = new MqttAsyncClient(brokerUrl, "test");

MqttConnectOptions connOpts = new MqttConnectOptions();
connOpts.setUserName("emqx_test");
connOpts.setPassword("emqx_test_password".toCharArray());
connOpts.setServerURIs(new String[] { brokerUrl });
connOpts.setCleanSession(true);

mqttClient.connect(connOpts, connStatus); // 问题所在

回调函数onFailure返回reason_code_failed_authentication错误码。 当禁用EMQX的内置数据库认证后,连接成功,但EMQX控制台显示缺少用户名。

解决方案

问题在于mqttClient.connect(connOpts, connStatus);这行代码。 为了正确进行用户名密码认证,需要修改为:

mqttClient.connect(connOpts, null, connStatus);

将第二个参数设为null,即可解决认证失败问题。 修改后,连接成功,并且用户名认证生效。

通过以上调整,即可解决Eclipse Paho MQTTAsyncClient连接本地EMQX时用户名密码认证失败的问题。

以上就是如何解决使用Eclipse Paho的MqttAsyncClient连接本地EMQX时用户名密码认证失败的问题?的详细内容,更多请关注知识资源分享宝库其它相关文章!

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。