繁体   English   中英

Android套接字连接麻烦

[英]Android socket connection troubles

我做了一个客户端(android(java)) - 服务器(node.js)应用程序。

问题是当我使用AVD模拟器(使用10.0.2.2或扩展IP)来测试我的程序时,ewerything运行良好,但当我尝试用手机或其他模拟器(genimotion,nox,bluestacks)做同样的事情时,我可以`完全连接。

用户需要使用互联网和Wi-Fi。 连接功能的代码是:

    public void Connect(String Host, int Port)
{
    try
    {
        System.out.println(Handlers.isEmpty());
        if (Handlers.isEmpty())
            throw new NullPointerException ("No handlers");

        if (Socket != null && Socket.isConnected())
            Socket.close();

        InetAddress IpAddress = InetAddress.getByName(Host);
        Address = new InetSocketAddress(IpAddress, Port);
        Socket = new Socket();
        Socket.setSoTimeout(1000);
        Socket.connect(Address, 1500);
        InputStream = new BufferedReader (new InputStreamReader(Socket.getInputStream()));
        OutputStream = new PrintWriter (Socket.getOutputStream());
        RThread = new ReadSocketThread(InputStream, Handlers, SearchName);
        ReadSocket = new Thread(RThread);
        ReadSocket.start();
    }
    catch (IOException e)
    {
        e.printStackTrace();
    }

}

而控制台说:

E/AndroidRuntime: FATAL EXCEPTION: main
              Process: bobko.alexandr.consultant, PID: 1599
              java.lang.IllegalStateException: Could not execute method for android:onClick
                  at android.support.v7.app.AppCompatViewInflater$DeclaredOnClickListener.onClick(AppCompatViewInflater.java:293)
                  at android.view.View.performClick(View.java:4438)
                  at android.view.View$PerformClick.run(View.java:18422)
                  at android.os.Handler.handleCallback(Handler.java:733)
                  at android.os.Handler.dispatchMessage(Handler.java:95)
                  at android.os.Looper.loop(Looper.java:136)
                  at android.app.ActivityThread.main(ActivityThread.java:5045)
                  at java.lang.reflect.Method.invokeNative(Native Method)
                  at java.lang.reflect.Method.invoke(Method.java:515)
                  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779)
                  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
                  at dalvik.system.NativeStart.main(Native Method)
               Caused by: java.lang.reflect.InvocationTargetException
                  at java.lang.reflect.Method.invokeNative(Native Method)
                  at java.lang.reflect.Method.invoke(Method.java:515)
                  at android.support.v7.app.AppCompatViewInflater$DeclaredOnClickListener.onClick(AppCompatViewInflater.java:288)
                  at android.view.View.performClick(View.java:4438) 
                  at android.view.View$PerformClick.run(View.java:18422) 
                  at android.os.Handler.handleCallback(Handler.java:733) 
                  at android.os.Handler.dispatchMessage(Handler.java:95) 
                  at android.os.Looper.loop(Looper.java:136) 
                  at android.app.ActivityThread.main(ActivityThread.java:5045) 
                  at java.lang.reflect.Method.invokeNative(Native Method) 
                  at java.lang.reflect.Method.invoke(Method.java:515) 
                  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779) 
                  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595) 
                  at dalvik.system.NativeStart.main(Native Method) 
               Caused by: android.os.NetworkOnMainThreadException
                  at android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1145)
                  at libcore.io.BlockGuardOs.connect(BlockGuardOs.java:84)
                  at libcore.io.IoBridge.connectErrno(IoBridge.java:144)
                  at libcore.io.IoBridge.connect(IoBridge.java:112)
                  at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:192)
                  at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:459)
                  at java.net.Socket.connect(Socket.java:843)
                  at bobko.alexandr.consultant.STAPLibrary.STAPLibraryMain.Connect(STAPLibraryMain.java:53)
                  at bobko.alexandr.consultant.MainActivity.Create(MainActivity.java:29)
                  at java.lang.reflect.Method.invokeNative(Native Method) 
                  at java.lang.reflect.Method.invoke(Method.java:515) 
                  at android.support.v7.app.AppCompatViewInflater$DeclaredOnClickListener.onClick(AppCompatViewInflater.java:288) 
                  at android.view.View.performClick(View.java:4438) 
                  at android.view.View$PerformClick.run(View.java:18422) 
                  at android.os.Handler.handleCallback(Handler.java:733) 
                  at android.os.Handler.dispatchMessage(Handler.java:95) 
                  at android.os.Looper.loop(Looper.java:136) 
                  at android.app.ActivityThread.main(ActivityThread.java:5045) 
                  at java.lang.reflect.Method.invokeNative(Native Method) 
                  at java.lang.reflect.Method.invoke(Method.java:515) 
                  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779) 
                  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595) 
                  at dalvik.system.NativeStart.main(Native Method) 

申请终止。

当您在主线程中执行网络操作时,会抛出NetworkOnMainThreadException 这就是你无法连接的原因。

您应该在AsyncTask包装连接到网络的代码,或者使用像Retrofit这样的库。 简单地说,网络操作必须在主UI线程以外的线程中运行。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM