JAVA服务端 Socket接收iOS发送的报文为空字符串?

发布于 2022-09-05 08:47:22 字数 3408 浏览 40 评论 0

原问题

问题是这样呢
我和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 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

以可爱出名 2022-09-12 08:47:22

我是题主哈,在这里占个位置。

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

//设置写入数据的超时时间为5毫秒
socket.setSoTimeout(5);

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


 catch (SocketTimeoutException e) {
 ......
 }

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

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文