Socket通讯正常想实现的流程:
是客户端给服务端发送发送报文,当服务端接收到报文后,给客户端一个反馈信息。
目前代码实现情况是:
客户端和服务端在read时都被阻塞了,经过反复的查阅相关资料和测试,发现了问题的根本。
导致read阻塞的原因是:
当客户端给服务端发送完数据的时候服务端在读取数据,但是服务端没有办法判断什么时候会自动中断,所以服务端会在这个地方阻塞。
阻塞之后服务端就没有办法往客户端发送数据,这个时候客户端的接收数据也会等服务端的数据,会在这里阻塞。这个时候服务端和客户端都不会关闭,会一直持续阻塞。客户端传递数据的时候,服务端不知道什么时候终止,用read!=-1是没有办法判断出来的,因为客户端流没有终止,流一直存在,所以服务端以为数据没有传输完毕。
有两个解决方案,方案如下:
1.在客户端传输结束之后,你可以把流进行关闭,使用socket.shutdownOutput()和socket.shutdownInput()这两个方法,将流关闭掉,对面就可以接收到结束的信号。
2.双方约定好,定义一个结束符,客户端每次给服务端发送报文时,在发送结束加上结束符;当服务端这面接收到报文读取时,读到结束符的话,就证明是结束了,就不在循环了。
方案1服务端代码:
package com.pactera.ok;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.io.PrintWriter;
import java.net.ServerSocket;
import java.net.Socket;
/**
* @Title:TestZLFServer
* @Description:
* @company:XXXXXX
* @author:XXXXXX-zhanglf
* @date:2017-5-16
* @version:1.0.0
*/
public class TestZLFServer {
public static void main(String[] args) {
try {
ServerSocket ss=new ServerSocket(10086);
Socket s=ss.accept();