Android上的jWebSocket客户端未连接到本地服务器

时间:2012-06-27 08:24:56

标签: android client websocket

我正在尝试在Android上启动一个非常简单的jWebSocket客户端并将其连接到我的本地服务器。我正在使用演示中的JWC类以及jWebSocket 1.0 beta 8和Android 4.0.3,我的代码如下所示:

import org.jwebsocket.api.WebSocketClientEvent;
import org.jwebsocket.api.WebSocketClientTokenListener;
import org.jwebsocket.api.WebSocketPacket;
import org.jwebsocket.client.token.BaseTokenClient;
import org.jwebsocket.kit.WebSocketException;
import org.jwebsocket.token.Token;

import android.app.Activity;
import android.content.Context;
import android.content.IntentFilter;
import android.os.Bundle;
import android.view.View;
import android.widget.ArrayAdapter;
import android.widget.Button;
import android.widget.Spinner;
import cased.smids.communication.JWC;

public class TasksActivity extends Activity implements WebSocketClientTokenListener {
   Spinner spinner;
   Button btn_Start;

    /** Called when the activity is first created. */
    @Override
    protected void onCreate(Bundle savedInstanceState)
    {
        super.onCreate(savedInstanceState);
        this.setContentView(R.layout.main);

        JWC.init();

        spinner = (Spinner)findViewById(R.id.sp_Task);
        btn_Start = (Button)findViewById(R.id.btn_Start);

        ArrayAdapter<CharSequence> adapter = 
                ArrayAdapter.createFromResource(
                        this,
                        R.array.Tasks,
                        android.R.layout.simple_spinner_item
                );
        adapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
        spinner.setAdapter(adapter);

        btn_Start.setOnClickListener(new View.OnClickListener() {
            public void onClick(View src) {
                switch (src.getId()) {
                    case R.id.btn_Start:
                        if (spinner.getSelectedItem().toString().equals("Connect")) {
                            try {
                                System.out.println("connecting manually...");
                                JWC.open();
                            } catch (WebSocketException e) {
                                e.printStackTrace();
                            }
                        }
                    default:
                        break;
                }
            }
        });
    }

    @Override
    protected void onResume() {
        super.onResume();
        System.out.println("* opening... ");
        try {
            JWC.addListener(this);
            JWC.open();
        } catch (WebSocketException ex) {
            System.out.println("* exception: " + ex.getMessage());
        }
    }

    @Override
    protected void onPause() {
        System.out.println("* closing... ");
        try {
            JWC.close();
            JWC.removeListener(this);
        } catch (WebSocketException ex) {
            System.out.println("* exception: " + ex.getMessage());
        }
        super.onPause();
    }

    public void processClosed(WebSocketClientEvent arg0) {
        System.out.println("closed");
    }

    public void processOpened(WebSocketClientEvent arg0) {
        System.out.println("opened");
    }

    public void processOpening(WebSocketClientEvent arg0) {
        System.out.println("opening");
    }

    public void processPacket(WebSocketClientEvent arg0, WebSocketPacket arg1) {
        System.out.println("packet");
    }

    public void processReconnecting(WebSocketClientEvent arg0) {
        System.out.println("reconnecting");
    }

    public void processToken(WebSocketClientEvent arg0, Token arg1) {
        System.out.println("token");
    }
}

所以基本上它只是一个微调器和一个按钮。现在,我想要做的就是连接到我的本地jWebSocketServer。 demo-app(来自网站的.apk包,如果我导入代码eclipse告诉我在编译代码之前删除许多“@Overwrite” - 在发生相同的“bug”之后)与我的服务器一起工作所以它必须是代码。现在,我得到的只是“连接......”,大约0.1秒后“关闭”。每一次。

顺便说一句。该应用程序具有正确的INTERNET和ACCESS_NETWORK_STATE,因此不应该是一个问题。

我将不胜感激任何帮助。

干杯

1 个答案:

答案 0 :(得分:2)

事实证明,BaseTokenClient.open()正在捕获所有异常并且对此无动于衷(无声失败)。在我的情况下 - NetworkOnMainThreadException。神秘解决了。