问题描述
我正在尝试使用Microsoft Azure IOT Hub(MQTT)将Java客户端设备连接到IOT Hub(不带SDK)。我根据需要使用TTL创建了设备和SAS。我正在使用Paho客户端连接到IoT中心。我遇到了以下错误。我从IoT中心工具创建的SAS令牌有效期为5小时。 无权连接(5个) 在org.eclipse.paho.client.mqttv3.internal.ExceptionHelper.createMqttException(ExceptionHelper.java:28) 在org.eclipse.paho.client.mqttv3.internal.ClientState.notifyReceivedAck(ClientState.java:1040) 在org.eclipse.paho.client.mqttv3.internal.CommsReceiver.run(CommsReceiver.java:151) 在java.lang.Thread.run(未知来源)
下面是我正在尝试的代码
String deviceid = "mqqdirectdevice1";
String brokerUri = "ssl://xxxxx:8883";
String clientId = deviceid;
System.out.println( "Connecting to " + brokerUri +" as "+clientId);
MqttAsyncclient client = null;
try {
String sasToken="SharedAccessSignature sr=xxxxxxx.azure-devices.net%2Fdevices%2Fmqqdirectdevice1&sig=iJ3jacTNMdyyhIrQueBN5X6uEqURYCKfa5Z63ePKDRs%3D&se=1600335545";
client = new MqttAsyncclient( brokerUri,clientId,new MemoryPersistence());
if ( client != null ) {
MqttConnectOptions options = new MqttConnectOptions();
client.setCallback( new AzureCallback() );
options.setUserName("xxxxxx.net/mqqdirectdevice1?api-version=2018-06-30");
options.setPassword(sasToken.tochararray());
// options.setPassword(sasToken.tochararray());
options.setKeepAliveInterval(230);
options.setCleanSession(false);
options.setMqttVersion(4);
IMqttToken token=client.connect( options );
token.waitForCompletion(60 * 1000);
System.out.println("Sent MQTT CONNECT packet was ackNowledged");
if ( client.isConnected() ) {
System.out.println( "Success!" );
} else {
System.out.println( "Could not connect to Azure IoT hub,timed-out" );
}
}
} catch ( MqttException) {
//client.getDebug().dumpBaseDebug();
e.printstacktrace();
} finally {
if ( client != null ) {
try {
client.disconnect();
} catch ( MqttException ignore ) {}
}
}
解决方法
在您的示例中,您使用以下用户名:
xxxxxx.net/mqqdirectdevice1?api-version=2018-06-30
格式略有不同,您当前在问号前缺少正斜杠。正确的格式是:
xxxxxx.net/mqqdirectdevice1/?api-version=2018-06-30
我对其进行了测试,并且无法使用错误格式的用户名建立MQTT连接。