JAVA服务端 Socket接收iOS发送的报文为空字符串?
原问题
问题是这样呢
我和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),这让我百思不得其姐啊
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
我是题主哈,在这里占个位置。
找到原因了,是设置了超时时间所致,但是不清楚问题的根源所在(如果超时时间设置成100毫秒,是能够正常接收数据的,目前出问题的超时时间是5毫秒,如下)
按道理说,如果超时,那么因该会跳转到超时的异常处理代码块中
但是它又不报超时异常,而是返回了空值(length = 0),这让我百思不得其姐啊