Клиент jquery signalr работает, но в java его нельзя заставить работать

У нас есть концентратор SignalR. Следующий код jQuery соединяется и корректно обрабатывает события «call» клиента SignalR на кордове.

var connectionURL = "https://SOMEURL.azurewebsites.net/message"; connection = $.connection(connectionURL); connection.start().done(function () { console.log("Connected to hub again"); }); connection.disconnected(function () { setTimeout(function () { connection.start().done(function () { console.log("Disconnected and Connected to hub again"); }); }, 5000); }); connection.stateChanged(function (change) { if (change.newState == $.signalR.connectionState.reconnecting) { } else if (change.newState == $.signalR.connectionState.connected) { } else if (change.newState == $.signalR.connectionState.disconnected) { }// else if }); connection.received(function (data) { connectId = connection.id + ""; console.log("onDeviceReady run"); // call the function to parse the data if (data.PayloadType == "Dispatch") { dataDispatch(data); } if (data.PayloadType == "ConnectionAcknowledge") { sendConnectionAcknowledge(data); } }); 

Однако, когда я пытаюсь эмулировать этот код в java android с помощью SignalR Java Client , я получаю много выходных данных журнала (тонны), и соединение никогда не заканчивается. Он доходит до отладки в строке awaitConnection.get(); И никогда не печатает вторую строку отладки, вместо этого она печатает бесконечные (тысячи) строк полубессознания (это не трубопровод, это похоже на какое-то «рукопожатие SSL», но это не делает ничего, кроме как повторять одно и то же много раз, очень странно ) В любом случае он никогда не запускает вторую строку «моей» отладки

 package com.some.thing; import android.util.Log; import java.util.concurrent.ExecutionException; import microsoft.aspnet.signalr.client.Platform; import microsoft.aspnet.signalr.client.SignalRFuture; import microsoft.aspnet.signalr.client.http.android.AndroidPlatformComponent; import microsoft.aspnet.signalr.client.hubs.HubConnection; import microsoft.aspnet.signalr.client.hubs.HubProxy; import microsoft.aspnet.signalr.client.hubs.SubscriptionHandler1; public class SignalRClient { public static void startConnection() { Platform.loadPlatformComponent(new AndroidPlatformComponent()); String host = "https://SOMEURL.azurewebsites.net/message"; HubConnection connection = new HubConnection(host); HubProxy hub = connection.createHubProxy( "IDoNoHaveThisNorKnowIt" ); SignalRFuture<Void> awaitConnection = connection.start(); try { Log.v("CONANSignalR :=", "CONNECTING"); awaitConnection.get(); Log.v("CONANSignalR :=", "CONNECTED"); } catch (InterruptedException e) { // Handle ... } catch (ExecutionException e) { // Handle ... } hub.on("IDoNotKnowThisEither", new SubscriptionHandler1<String>(){ @Override public void run( String status ){ Log.v("CONANDispatch :=", status); } }, String.class); } } 

Может ли кто-нибудь помочь мне перевести рабочий код клиента jQuery SignalR в пригодный для использования код java-клиента? У меня нет информации о хабе, поэтому я не могу знать прокси или имена функций, я бы хотел увидеть все (например, jQuery).

РЕДАКТИРОВАТЬ

Чтобы проверить вещи, я изменил свой исходный код jquery, который он использует, чтобы сказать

 console.log("onDeviceReady run"); 

Теперь он говорит

 console.log("SignalR Raw Data:" + JSON.stringify(data)); 

Когда я это делаю, это то, что возвращает jquery

 SignalR Raw Data:{"ConnectionId":"9c4b4ba5-cb6e-4dcb-8df9-069cbf749873","OrderId":null,"SenderId":null,"PayloadType":"ConnectionAck","Message":"Welcome, you are connected to the Hub!","Payload":null,"Initiator":"HUB","Version":null} 

Однако ничто из этого не появляется внутри java-эквивалента

 connection.received(new MessageReceivedHandler() { @Override public void onMessageReceived(JsonElement json) { System.out.println("RAW received message: " + json.toString()); // ADD HANDLING OF RECEIVED IN HERE } }); 

Т.е. текст «полученное сообщение RAW:» вообще не отображается

Solutions Collecting From Web of "Клиент jquery signalr работает, но в java его нельзя заставить работать"

Поскольку вы не знаете имя узла, вам нужно напрямую использовать события обработки на объекте подключения (например, вы делаете в js-клиенте).

Вот пример кода, который мог бы начать вас (обратите внимание, что это не проверено, написано только с головы):

 public static void startConnection() { Platform.loadPlatformComponent(new AndroidPlatformComponent()); String host = "https://SOMEURL.azurewebsites.net/message"; HubConnection connection = new HubConnection(host); // subscribe to received - equal to `connection.received(function (data)` from javascript connection.received(new MessageReceivedHandler() { @Override public void onMessageReceived(JsonElement json) { System.out.println("RAW received message: " + json.toString()); // ADD HANDLING OF RECEIVED IN HERE } }); // equal to `connection.disconnected(function ()` from javascript connection.closed(new Runnable() { @Override public void run() { // ADD CODE TO HANDLE DISCONNECTED EVENT } }); // equal to `connection.stateChanged(function (change)` connection.stateChanged(new StateChangedCallback() { @Override public void stateChanged(ConnectionState oldState, ConnectionState newState) { // ADD CODE TO HANDLE STATE CHANGES } }); // start the connection connection.start() .done(new Action<Void>() { @Override public void run(Void obj) throws Exception { System.out.println("Connected"); } }); } 

Кроме того, я рекомендую вам проверить пример чата-клиента для java, который можно найти здесь: https://github.com/SignalR/java-samples/blob/master/signalr-sample-chat/src/microsoft/aspnet/signalr/ образцы / чат / Program.java

Большая часть кода, который я опубликовал, основана на этом.