Android Raspberry pi W / System.err(13264):java.net.ConnectException连接被拒绝

时间:2013-08-05 06:45:14

标签: android tcp raspberry-pi iptables netcat

你好我是linux和android编程的新手,我的想法是通过TCP套接字从Raspberry Pi发送数据包到Android手机。 当连接开始时,数据流很好,经过少量数据发送流后,有时会“卡住”。

我的Android手机IP 192.168.43.1 我的静态Raspberry IP 192.168.43.5

我尝试更改端口号但连接仍然卡住,我尝试减少数据包数据的大小但仍然卡住。我假设树莓防火墙(如果存在)是问题或者可能是iptables配置,但如何检查和禁用Raspberry防火墙?只是信息,在我的覆盆子没有firestarter。或者如何使用iptables?

你能帮助我为什么会这样吗?或者任何参考都会很棒,提前谢谢!这是我的logcat:

07-30 13:11:20.731: W/System.err(13264): java.net.ConnectException: failed to connect to /192.168.43.20 (port 12345): connect failed: ECONNREFUSED (Connection refused)
07-30 13:11:20.731: W/System.err(13264):   at libcore.io.IoBridge.connect(IoBridge.java:118)
07-30 13:11:20.731: W/System.err(13264):   at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:192)
07-30 13:11:20.731: W/System.err(13264):   at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:172)
07-30 13:11:20.731: W/System.err(13264):   at java.net.Socket.startupSocket(Socket.java:571)
07-30 13:11:20.731: W/System.err(13264):   at java.net.Socket.tryAllAddresses(Socket.java:132)
07-30 13:11:20.731: W/System.err(13264):   at java.net.Socket.<init>(Socket.java:182)
07-30 13:11:20.731: W/System.err(13264):   at java.net.Socket.<init>(Socket.java:154)
07-30 13:11:20.731: W/System.err(13264):   at com.uavgama.Streamingdata.Masukan(Streamingdata.java:19)
07-30 13:11:20.731: W/System.err(13264):   at com.uavgama.Adhrsparse.Keluar(Adhrsparse.java:71)
07-30 13:11:20.731: W/System.err(13264):   at com.uavgama.Adhrsparse$1.run(Adhrsparse.java:26)
07-30 13:11:20.731: W/System.err(13264):   at android.os.Handler.handleCallback(Handler.java:615)
07-30 13:11:20.731: W/System.err(13264):   at android.os.Handler.dispatchMessage(Handler.java:92)
07-30 13:11:20.731: W/System.err(13264):   at android.os.Looper.loop(Looper.java:137)
07-30 13:11:20.731: W/System.err(13264):   at android.app.ActivityThread.main(ActivityThread.java:4744)
07-30 13:11:20.731: W/System.err(13264):   at java.lang.reflect.Method.invokeNative(Native Method)
07-30 13:11:20.741: W/System.err(13264):   at java.lang.reflect.Method.invoke(Method.java:511)
07-30 13:11:20.741: W/System.err(13264):   at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786)
07-30 13:11:20.741: W/System.err(13264):   at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
07-30 13:11:20.741: W/System.err(13264):   at dalvik.system.NativeStart.main(Native Method)
07-30 13:11:20.741: W/System.err(13264): Caused by: libcore.io.ErrnoException: connect failed: ECONNREFUSED (Connection refused)
07-30 13:11:20.741: W/System.err(13264):   at libcore.io.Posix.connect(Native Method)
07-30 13:11:20.741: W/System.err(13264):   at libcore.io.BlockGuardOs.connect(BlockGuardOs.java:85)
07-30 13:11:20.741: W/System.err(13264):   at libcore.io.IoBridge.connectErrno(IoBridge.java:131)
07-30 13:11:20.741: W/System.err(13264):   at libcore.io.IoBridge.connect(IoBridge.java:116)
07-30 13:11:20.741: W/System.err(13264):   ... 18 more

以下是我以前发送的打包数据:

$909.29|34.16|160.39907|123.51508|189.56|40.42|339.78#
$62.88|52.38|32.62654|170.11087|19.19|99.57|127.72#
$847.45|65.29|128.59294|114.23773|161.92|268.55|28.90#
$957.35|48.49|142.63874|9.20948|161.73|297.63|348.33#
$634.97|25.16|105.1316|23.51827|185.56|195.88|189.1#
format :
$altitude|airspeed|lat|lon|pitch|roll|yaw#

这是用于发送数据的覆盆子bash代码

cat /home/pi/file | awk -F'\t' 'END{print}' | nc -l 12345

这是我的数据流java代码:

 public static String Masukan() {
try {
    Socket s;
    s = new Socket("192.168.43.20", 12345);
    s.getReuseAddress();
    s.getTcpNoDelay();
    BufferedReader inp = null;
    inp = new BufferedReader(new InputStreamReader(s.getInputStream()));
    String serverMsg = null;
    serverMsg = inp.readLine();
        if ( serverMsg.endsWith("#")) {
                filter = serverMsg; 
                s.close();
            }

} catch (IOException e) {
            e.printStackTrace();
            }
return filter; 

    };

1 个答案:

答案 0 :(得分:1)

这里有许多奇怪的事情发生。

您可能想在netcat上尝试-k标志 - 这意味着连接将保持不变。

你的awk脚本似乎确保只发送文件的最后一行。这是故意的吗?

你在java代码中做了一个相当暴力的挂断 - 当你收到消息时,你关闭套接字。考虑阅读所有消息,过滤掉您需要的内容,最后在finally块中关闭套接字。 (关闭finally块中的资源总是一个好主意。)