‘壹’ java socket输入流inputStream.read(byte[])方法一次读入多帧数据,也就是多帧数据连在一起
在使用Java Socket的inputStream.read(byte[])方法时,如果服务端发送数据的速度超过客户端读取的速度,客户端可能会一次性读取到多帧数据连在一起的情况。这种情况下,数据包的读取和处理就需要特别注意。一种处理方式是在服务端将每一帧数据作为一行写入Socket,客户端则通过BufferedReader逐行读取。这样可以确保每次读取的数据都是一个完整的数据帧。
具体实现步骤如下:
1. 在服务端使用PrintWriter将数据帧作为一行写入Socket输出流:
2. 代码示例如下:
java
PrintWriter writer = new PrintWriter(socket.getOutputStream());
writer.println(data);
2. 在客户端,通过BufferedReader逐行读取Socket输入流的数据:
2. 代码示例如下:
java
BufferedReader reader = new BufferedReader(new BufferedInputStream(socket.getInputStream()));
String s = reader.readLine();
这种方式可以确保客户端每次读取到的数据都是一个完整的数据帧,而不会出现多帧数据连在一起的情况。通过这种方式,可以更好地管理和处理Socket通信中不同帧数据的读取。
使用这种方法处理数据帧时,需要注意的是,每一帧数据必须以换行符结束,这样才能被正确地解析为一行。此外,客户端在读取每一行数据后,应该进行适当的解析和处理,以确保数据的完整性和正确性。
通过这种方式处理数据帧,可以有效地解决服务端发送数据速度过快,而客户端读取速度较慢的问题,从而提高数据通信的稳定性和可靠性。
‘贰’ JAVA服务器接收byte数组的问题
可以这样塌激做,
但没团咐袜有读取内容简耐时,inputStream.read(left)会一直等待读取,直到有数据接入或者抛出超时异常,
java.net.SocketTimeoutException
‘叁’ java socket输入流inputStream.read(byte[])方法一次读入多帧数据,也就是多帧数据连在一起
因为inputStream.read(byte)是尽可能的读byte[]大小的数据,当你的服务端发送数据速度大于客户端读取数据的速度时,就会出现客户端读到多帧连在一起的报文。而这些发送数据,读取数据的速度是未知的。所以我们需要人为的来做一些调整。比如说每一帧作为一行写入Socket,客户端每次从socket读取一行。这样客户端每次都是读取一帧。
以上情况可以这样实现:在服务端使用PrintWriter
PrintWriterwriter=newPrintWriter(socket.getOutputStream());
writer.println(data);
客户端可以使用BufferedReader
BufferedReaderreader=newBufferedReader(newBufferedInputStream(socket.getInputStream()));
Strings=reader.readLine();
‘肆’ java 里面的string 和byte 怎么互转
1.string 转 byte[]
byte[] midbytes=isoString.getBytes("UTF8");
//为UTF8编码
byte[] isoret = srt2.getBytes("ISO-8859-1");
//为ISO-8859-1编码
其中ISO-8859-1为单字节的编码
2.byte[]转string
String isoString = new String(bytes,"ISO-8859-1");
String srt2=new String(midbytes,"UTF-8");
说明:
在网络传输或其它应用中常常有同一的中间件,假设为String类型。因此需要把其它类型的数据转换为中间件的类型。
将字符串进行网络传输时,如socket,需要将其在转换为byte[]类型。这中间如果采用用不同的编码可能会出现未成预料的问题,如乱码。
下面举个例子:
我们用socket传输String类型的数据时,常常用UTF-8进行编码,这样比较可以避免一个“中文乱码”的问题。
发送端:
String sendString="发送数据";
byte[] sendBytes= sendString .getBytes("UTF8");
.......socket发送
接受端:
String recString=new String( sendBytes ,"UTF-8");
但是,这里往往又会出现这样一个问题。就是想要发送的数据本身就是byte[]类型的。
如果将其通过UTF-8编码转换为中间件String类型就会出现问题
如:
byte[] bytes = new byte[] { 50, 0, -1, 28, -24 };
String sendString=new String( bytes ,"UTF-8");
byte[] sendBytes= sendString .getBytes("UTF8");
然后再发送
接受时进行逆向转换
String recString=new String( sendBytes ,"UTF-8");
byte[] Mybytes=isoString.getBytes("UTF8");
这时Mybytes中的数据将是[50, 0, -17, -65, -67, 28, -17, -65, -67]
因此,需要采用单字节的编码方式进行转换
String sendString=new String( bytes ,"UTF-8"); 改为 String sendString=new String( bytes , "ISO-8859-1" );
byte[] Mybytes=isoString.getBytes("UTF8"); 改为 byte[] Mybytes=isoString.getBytes( "ISO-8859-1" );
这样所需要的字节就有恢复了。