带有本地IP地址的简单客户端服务器程序

时间:2013-07-21 21:33:27

标签: java android networking client-server

我正在尝试使用基本的客户端服务器。我在我的一台计算机上运行了Java服务器套接字程序。我的Android手机运行的是一个简单的应用程序,并充当客户端。我希望手机能够连接到我电脑上的Java程序。

客户端尝试连接到我的计算机的本地IP地址,但我无法连接它。我得到一个IOException。这是我正在使用的Android代码:

        try {
            echoSocket = new Socket("192.168.0.19", 7077);
            System.out.println("length: "+ "socket created!");
        } catch (UnknownHostException e) {
            System.out.println("length: "+ "Don't know about host.");
        } catch (IOException e) {
            System.out.println("Couldn't get I/O for "
                    + "the connection.");
        }

如果我在我的计算机上同时运行客户端和服务器,然后尝试连接到计算机的本地IP(与上面相同),则可以正常工作。但我想通过手机连接。

任何想法我需要做什么?

编辑:这是堆栈跟踪:

   07-21 15:37:34.223: W/System.err(3474): android.os.NetworkOnMainThreadException
07-21 15:37:34.223: W/System.err(3474):     at android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1117)
07-21 15:37:34.223: W/System.err(3474):     at libcore.io.BlockGuardOs.connect(BlockGuardOs.java:84)
07-21 15:37:34.223: W/System.err(3474):     at libcore.io.IoBridge.connectErrno(IoBridge.java:127)
07-21 15:37:34.223: W/System.err(3474):     at libcore.io.IoBridge.connect(IoBridge.java:112)
07-21 15:37:34.223: W/System.err(3474):     at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:192)
07-21 15:37:34.223: W/System.err(3474):     at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:172)
07-21 15:37:34.223: W/System.err(3474):     at java.net.Socket.startupSocket(Socket.java:566)
07-21 15:37:34.223: W/System.err(3474):     at java.net.Socket.tryAllAddresses(Socket.java:127)
07-21 15:37:34.223: W/System.err(3474):     at java.net.Socket.<init>(Socket.java:177)
07-21 15:37:34.223: W/System.err(3474):     at java.net.Socket.<init>(Socket.java:149)
07-21 15:37:34.223: W/System.err(3474):     at com.nikhildev.cricketeye.MainActivity.startVideoCamera(MainActivity.java:45)
07-21 15:37:34.223: W/System.err(3474):     at java.lang.reflect.Method.invokeNative(Native Method)
07-21 15:37:34.223: W/System.err(3474):     at java.lang.reflect.Method.invoke(Method.java:511)
07-21 15:37:34.223: W/System.err(3474):     at android.view.View$1.onClick(View.java:3594)
07-21 15:37:34.223: W/System.err(3474):     at android.view.View.performClick(View.java:4204)
07-21 15:37:34.223: W/System.err(3474):     at android.view.View$PerformClick.run(View.java:17355)
07-21 15:37:34.223: W/System.err(3474):     at android.os.Handler.handleCallback(Handler.java:725)
07-21 15:37:34.223: W/System.err(3474):     at android.os.Handler.dispatchMessage(Handler.java:92)
07-21 15:37:34.223: W/System.err(3474):     at android.os.Looper.loop(Looper.java:137)
07-21 15:37:34.223: W/System.err(3474):     at android.app.ActivityThread.main(ActivityThread.java:5041)
07-21 15:37:34.233: W/System.err(3474):     at java.lang.reflect.Method.invokeNative(Native Method)
07-21 15:37:34.233: W/System.err(3474):     at java.lang.reflect.Method.invoke(Method.java:511)
07-21 15:37:34.233: W/System.err(3474):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
07-21 15:37:34.233: W/System.err(3474):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
07-21 15:37:34.233: W/System.err(3474):     at dalvik.system.NativeStart.main(Native Method)

1 个答案:

答案 0 :(得分:0)

使用Android和套接字,您需要注意一些事情

  1. Android需要成为客户端,因为其IP地址预计会比服务器更频繁地更改
  2. 您使用的端口号应为&gt; 1024
  3. 如果在模拟器上,您需要知道模拟器的IP是10.something。查看Android文档。
  4. 清单中的权限
  5. 最后,您的问题是您在主UI线程中运行网络API。您需要在异步任务中运行相同的操作。这就是为什么你得到StrictMode异常的东西。

    编辑:

    对于ping,请检查是否可以ping到网络路由器。如果您可以ping通外部世界,那么您的问题是您的路由器阻止ping内部。