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时用户名密码认证失败的问题?的详细内容,更多请关注代码网其它相关文章!
发表评论