-1

アプリで websocket を使用して新しいメッセージを確認しています。Service クラスに Websocket が実装されています。サービスを停止したい場合 (Activity で stopService を使用)、disconnect websocket を呼び出す必要がありますが、メソッドonCloseは呼び出されません。

ここにいくつかのコードがあります:

 @Override
public int onStartCommand(Intent intent, int flags, int startId) {

    start();

    super.onStartCommand(intent, flags, startId);

    return Service.START_STICKY;
}

@Override
public void onDestroy() {
    Log.i("tag", "onDestroy service start");

    Intent intent = new Intent(this, RepeatingAlarmService.class);

    if (alarmManager != null) {
        alarmManager.cancel(PendingIntent.getBroadcast(this, REQUEST_CODE, intent, 0));
    }

    mConnection.disconnect();  // this line doesn't work ???

    super.onDestroy();

    Log.i("tag", "service stopped");
}


private void start() {
    final String uri = "ws://ws.blabla.com"
    try {

        mConnection.connect(uri, new WebSocketConnectionHandler(){
            @Override
            public void onOpen() {
                Log.i("tag", "Socket open"); // this line work well

                super.onOpen();
            }

            @Override
            public void onClose(int code, String reason) {
                Log.i("tag", "Socket closed " + String.format("code: %d, reason: %s", code, reason));  // this line doesn't been printed
                }

                super.onClose(code, reason);
            }

            @Override
            public void onTextMessage(String payload) {              
                Log.i("tag", payload); // this line work well

                super.onTextMessage(payload);
            }
        });
    } catch(Exception ex) {

    }
}
4

1 に答える 1