Java与设备TCP长连接中发生的设备断开连接解决方法。

问题描述:

1、当与硬件设备通信正常时,硬件设备发送一次数据,java这里就能就收到,处理完成后阻塞在read处。
2、在我的测试中,当硬件设备的TCP连接断开时java的程序并没有抛出异常,而是表现出来不在read处阻塞了,一直在我的while循环里周而复始的运行程序。如果读进byte的话就是表现出来一直等于-1,readLine就是等于null。
3、当对方未断开时设备重启(发现我的read一直阻塞到那里,没有断开),而且不能将对方未发送数据时的阻塞和设备重启时的阻塞区分开。

解决方法:

1、从上面2中得出,当判断出等于-1或者null时,表示已经断开连接,否则会一直阻塞在read处,因此当等于那两个值时,break出while大循环,然后finally关闭所有流后递归调用该启动TCP的方法即可。
2、对应上面的3,发现还是可以利用设置超时阻塞时间,在read阻塞处将这个异常catch(SocketTimeOutException )住,然后在catch中判断当前连接是否断开,未断开的话就继续阻塞,否则重新与对方获取连接。

tmp为写入数据的字节数组

一次接收完所有传输过来的数据

len = inputStream.read(tmp);
if(len!=-1){
    
    
	//执行数据处理步骤
}
else {
    
    
	break;//跳出自己的循环
}

多次接收接受完数据

while((len=inputStream.read(tmp))!=-1){
    
    
	//满足自己的接收条件时break退出,因为是break退出,len不会为-1
}
if(len==-1){
    
    
	break;//跳出自己的循环
}else {
    
    
	//处理数据
}

关闭流后递归调用重新开启整个TCP的方法

finally {
    
    
            IoUtils.closeIo(server,socket,inputStream,outputStream);//关闭流
            main(new String[1]);//递归调用的重新开始整个TCP连接的方法
        }

判断是设备重启阻塞还是未发送数据阻塞

判断端口未使用代码,经测试这个不行,因为断开时检测到端口还在使用。因此,换成发送数据,用try,catch捕捉这个SocketIOException,如果捕捉到了说明端口已经断开,反之没断开。

try{
    
    
	in.read(tmp);
}catch(SocketTimeOutException ignored){
    
    
	try{
    
    
		out.write("123".getBytes);//发送内容随意
	}catch(IOException e){
    
    
		//捕捉到说明断开了
		break;
	}
	//走到这说明没有断开
	continue;
}

猜你喜欢

转载自blog.csdn.net/wflsyf/article/details/117301074
今日推荐