Android-приложение не получило данные от концентратора SignalR

Я уже прочитал эти темы:
как использовать SignalR в Android
Клиент Android не получает данные, а клиент.net получает данные с сервера SignalR

Я пишу простую систему чата с Android, которая работает с SignalR.
Предполагается, что клиенты отправляют сообщения (по телефону SendMessage метод на сервере) и сервер должен вызвать NewMessage метод на клиентов.

Вот мой ChatHub Класс (упрощенный) написан на C#.

public class ChatHub : Hub
{
    // Store the clients connections Id
    static readonly List<string> _connectedClients;

    public override Task OnConnected()
    {
        // Keep connections id
        // This section works fine and when the android device connects to the server,
        // Its connection id will stored.
        _connectedClients.Add(Context.ConnectionId)

        //... other codes
    }

    public void SendMessage(string message)
    {
        foreach (var connectionId in _connectedClients)
        {
            // according to the logs 
            // android device connection id exists here
            // and it works fine.
            Clients.Client(connectionId).NewMessage(message);
        }
    }
}

Когда клиент Android подключается к серверу, на OnConnected метод, идентификатор соединения будет сохранен в _connectedClients и работает нормально.

в SendMessage метод ChatHub класс, у нас есть идентификатор подключения устройства Android, и я уверен, что устройство Android находится в списке

А вот и мои коды Andoird:

public class ChatActivity extends AppCompatActivity
{
    // private fields
    HubConnection connection;
    HubProxy hub;
    ClientTransport transport;

    protected void onCreate(Bundle savedInstanceState) {

        Logger logger = new Logger() {
            @Override
            public void log(String message, LogLevel logLevel) {
                Log.e("SignalR", message);
            }
        };

        Platform.loadPlatformComponent(new AndroidPlatformComponent());
        connection = new HubConnection("192.168.1.100");
        hub = connection.createHubProxy("chatHub"); // case insensitivity

        transport = new LongPollingTransport(connection.getLogger());

        // no difference when using this:
        //transport = new ServerSentEventsTransport(connection.getLogger());

        // this event never fired!
        hub.subscribe(new Object() {
            public void NewMessage(String message)
            {
                Log.d("<Debug", "new message received in subscribe"); // won't work!
            }
        }

        // this event never fired!
        hub.on("NewMessage", new SubscriptionHandler() {
            @Override
            public void run() {
                Log.d("<Debug", "new message received in `on`"); // won't work!
            }
        });

        // connect to the server that works fine.
        SignalRFuture<Void> awaitConnection = connection.start(transport);
        try {
            awaitConnection.get(); // seems useless when using this or not!
        }
        catch (Exception ex) {
        }

        // this method works fine.
        hub.invoke("sendMessage", "this is a test message to the server")
        .done(new Action<Void>() {
                @Override
                public void run(Void aVoid) throws Exception {
                    Log.d("<Debug", "message sent."); // Works fine
                }
        });

    }
}

В приведенном выше коде Java, вызывая sendMessage на сервере работает нормально и сервер получает сообщения.
Но единственная проблема заключается в том, что hub.on(...) или же hub.subscribe(...) события никогда не вызываются сервером.
В простом описании Мое приложение может отправлять сообщения, но не может получать сообщения от других.
Любое предложение будет оценено.

2 ответа

Решение

Для фьючерсов это то, как я наконец-то получил ответ (пожалуйста, сначала прочитайте вопрос коды Android):

public class ChatActivity extends AppCompatActivity
{
    // private fields
    HubConnection connection;
    HubProxy hub;
    ClientTransport transport;

    protected void onCreate(Bundle savedInstanceState) {

        Logger logger = new Logger() {
            @Override
            public void log(String message, LogLevel logLevel) {
                Log.e("SignalR", message);
            }
        };

        Platform.loadPlatformComponent(new AndroidPlatformComponent());
        connection = new HubConnection("192.168.1.100");
        hub = connection.createHubProxy("chatHub"); // case insensitivity

        /* ****new codes here**** */
        hub.subscribe(this);

        transport = new LongPollingTransport(connection.getLogger());

        /* ****new codes here**** */
        connection.start(transport);

        /* ****new codes here**** */
        /* ****seems useless but should be here!**** */
        hub.subscribe(new Object() {
            @SuppressWarnings("unused")
            public void newMessage(final String message, final String messageId, final String chatId,
                                   final String senderUserId, final String fileUrl, final String replyToMessageId) {


            }
        });


        /* ********************** */
        /* ****new codes here**** */
        /* **** the main method that I fetch data from server**** */
        connection.received(new MessageReceivedHandler() {
            @Override
            public void onMessageReceived(final JsonElement json) {
                runOnUiThread(new Runnable() {
                    public void run() {
                        JsonObject jsonObject = json.getAsJsonObject();
                        Log.e("<Debug>", "response = " + jsonObject.toString());

                    }
                });
            }
        });
        /* ********************** */

    }
}

!важная заметка:
Приоритет кодов важен. Вот как я исправляю свою проблему в этой теме.

Вы не предоставляете параметры на своей стороне клиента, которые должны быть такими же, как на вашей стороне сайта. Код должен быть ниже:

      hub.on("NewMessage", new SubscriptionHandler1<String>() {
        @Override
        public void run(String message) {
            Log.d("<Debug", "new message received in `on`"); 
        }
    },String.class);  //do not forget say the String class in the end
Другие вопросы по тегам