java socket 读取为空_JAVA服务端 Socket接收iOS发送的报文为空字符串?

在本地环境中,Java Socket 服务端能正常接收iOS客户端数据,但部署到CentOS服务器上后,接收变为空字符串。问题与Socket的超时设置有关,当设置超时时间为5毫秒时,出现异常情况。尽管不应出现超时,但实际返回了空值而非抛出超时异常。调整超时时间到100毫秒解决了问题,但问题的根源仍需进一步探究。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

原问题

问题是这样呢

我和iOS两个人在本地调试的时候,我直接运行java项目,然后让他直接连接我的IP地址、相应端口号,这时候能够正常的接收到iOS客户端发送的数据,一切正常。

诡异的事情来了。。。

将这个代码打包成.war文件上传到服务器后,接收到iOS客户端的报文就是空字符串了(不是null哦),但是Android又是正常的,这是怎么回事呢?

PS:我的PC是Mac,服务端是CentOS7 系统。

//设置线程名称,如果已经设置了,则无须再次设置

String vname = Thread.currentThread().getName().substring(0, 5);

if (!vname.equals("长连接专用")) {

String name = "长连接专用socket线程-" + System.currentTimeMillis();

Thread.currentThread().setName(name);

}

//输入流

InputStream input = null;

try {

//设置写入数据的超时时间为5毫秒

socket.setSoTimeout(5);

input = socket.getInputStream();

BufferedReader br = new BufferedReader(new InputStreamReader(input));

String receive = br.readLine();

int index = 0;

while (receive != null && receive.equals("200")) {

receive = br.readLine();

index++;

if (index == 10) {

output(SetResultUtils.getResults(ResultState.FAILURE, "发送数据异常,连接断开"), null);

closeSocket();

}

}

if (receive == null) {

output(SetResultUtils.getResults(ResultState.FAILURE, "接收到了null值"), null);

return;

}

if (receive.isEmpty()){

Logs.getLogger().info("请求参数:" + receive.length());

output(SetResultUtils.getResults(ResultState.FAILURE, "接收到了空值"), null);

return;

}

Logs.getLogger().info("请求参数:" + receive);

//转成参数类,取出需要调用的服务名称

BaseSocketModel smodel = JsonUtils.getUtils().fromJson(receive, BaseSocketModel.class);

if (socket.getInetAddress().getHostAddress() != null) {

Logs.getLogger().info("请求ip:" + socket.getInetAddress().getHostAddress());

}

//给取出socket客户端的IP地址

smodel.setIp(socket.getInetAddress().getHostAddress());

//获取服务名称

String faceName = smodel.getFaceName();

//获取方法名称

String method = smodel.getMethod();

//获取设置了IP的请求参数

String param = smodel.toString();

//将请求参数放入object对象数组中

Object[] os = new Object[]{param};

//获取返回值

methodParam = (PlayMethodParam) ReflexUnified.getReflex().reflex(faceName, method, os);

//返回数据

output(methodParam.result, null);

} catch (SocketTimeoutException e) {

if (this.socketModel.getStatus() == 2)

this.socketModel.setStatus(1);

} catch (IOException e) {

Logs.getLogger().error("IOException:" + e.toString());

output(SetResultUtils.getResults(ResultState.FAILURE, "错误请求1"), null);

closeSocket();

} catch (Exception e) {

Logs.getLogger().error("Exception:", e);

output(SetResultUtils.getResults(ResultState.FAILURE, "错误请求2"), null);

}

解决后的新问题

找到原因了,是设置了超时时间所致,但是不清楚问题的根源所在(如果超时时间设置成100毫秒,是能够正常接收数据的,目前出问题的超时时间是5毫秒,如下

//设置写入数据的超时时间为5毫秒

socket.setSoTimeout(5);

按道理说,如果超时,那么因该会跳转到超时的异常处理代码块中

catch (SocketTimeoutException e) {

......

}

但是它又不报超时异常,而是返回了空值(length = 0),这让我百思不得其姐啊

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值