アプリで 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) {
}
}