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