我正在尝试使用基本的客户端服务器。我在我的一台计算机上运行了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)
答案 0 :(得分:0)
使用Android和套接字,您需要注意一些事情
最后,您的问题是您在主UI线程中运行网络API。您需要在异步任务中运行相同的操作。这就是为什么你得到StrictMode异常的东西。
编辑:
对于ping,请检查是否可以ping到网络路由器。如果您可以ping通外部世界,那么您的问题是您的路由器阻止ping内部。