WebSocket消息类型 入门篇(三)
websocker实现通讯基础(消息类型,消息转码/解码基础)
WebSocket协议支持三种本地消息类型
1、文本消息 2、二进制消息 3、Ping消息 和 Pong消息
无论是注解式端点还是变成是端点,实现其发送消息的API都是相同的
RemoteEndPoint接口和他的子类RemoteEndPoint.Basic(同步发送) 和 RemoteEndpoint.Async(异步发送) 提供了发送消息的所有方法
Ping 和 Pong消息的作用:
1)两种消息通常被用来检查WebSocket连接的健康性,(连接是否有效)。 2)可以通过测量Ping和Pong消息所花费的时间来测算WebSocket连接的效率。
消息发送(同步发送)
同步发送机制是由RemoteEndPoint接口的子类RemoteEndPoint.Basic实现同步发送消息的所有方法。
RemoteEndPoint.Basic API提供了三种发送字符串的方法
第一种:
该方法把传入的文本参数发送WebSocket文本信息发送,这意味着WebSocket连接的另一端将接受一个文本格式的信息,
只有在消息发送成功或者消息发送过程中抛出错误时,该方法才会返回(异常返回:发送过程中连接断开)
方法:public void sendText(String var1) throws IOException;
第二种
WebSocket提供了一种使用WriterAPI发送String消息的方式(用于将一些高层级的对象序列化String以便发送)
方法:public Writer getSendWriter() throws IOException;
第三种
WebSocket协议允许把大的WebSocket消息分解成多个小片段,使实现在整个消息被完全传送之前开始发送消息,并获得性能优化。(分片发送)
方法:public void sendText(String var1, boolean var2) throws IOException; //var2是消息结束标识,如果消息未结束则为false,如果消息为最后消息片段则为true。
RemoteEndPoint.Basic API提供了三种发送二进制消息的方法
第一种
和第一种发送字符串方法一样,一次发送完整信息,只有在消息完全发送成功,或者发送过程中抛出异常才会返回。
方法:public void sendBinary(ByteBuffer var1) throws IOException;
第二种
分片发送二进制消息
方法:public void sendBinary(ByteBuffer var1, boolean var2) throws IOException; /var2是消息结束标识,如果消息未结束则为false,如果消息为最后消息片段则为true。
第三种
实现通过输出流来发送消息,如果直接将java对象写入Java I/O的API时,这种方式将变得非常有用。
方法:public OutputStream getSendStream() throws IOException;
WebSocket是怎么将对象变为WebSocket信息的?
1)如果你传入的是一个java基本类型(等值于一个装箱类),WebSocket实际上会把数据转化成一个标准的Java字符串。
2)如果传入的是其他对象(除String类型),WebSocket会实现javax.websocket.Encoder.Text<T> T 就是你想要发送的对象类型。
当你使用WebSocket发送T类型的对象时,WebSocket会调用相应的解码器,发送给远端的实际上是encode()方法返回的字符串。 当编码器无法进行转换时就会抛出EncodeException异常。 传入其他对象(除String类型)实现: 一、如果想把对象编码成WebSocket二进制信息,可以实现Encoder.Binary<T>接口。 二、如果想把对象编码成Java I/O流,可以实现Encoder.CharacterStream<T> 、Encoder.BinaryStream<T>
注意:
1)要自己定义编码器,将信息编码为自己要传输的格式
案例:public class DrawingEncoder implements Encoder.Text<DrawingObject> {} //编码器:将DrawingObject转化为String类型
2)同时要在服务器端点配置定义的编码器。
@ServerEndpoint(
value= "/fruit_tree", encoders = { DrawingEncoder.class }
)
编码器:Encoder
编码器接口类型:
编码接口 转换 主要方法
Encoder.Text<T> T转换成String类型 String encode(T object)
Encoder.TextStream<T> T转换成Writer void encode(T object,Writer writer)
Encoder.Binary<T> T转换成ByteBuffer ByteBuffer encode(T object)
Encoder.BinaryStream<T> T转换成OutputStream void encode(T object,OutputStream os)
消息接收
消息接收方法及其参数类型
参数类型 处理消息类型 方法示例
String 文本消息 public void handleMessage(String Message) {}
String、boolean 文本消息片段 public void handleMessage(String Message,boolean isLast) {}
Reader 文本消息流 public void handleMessage(Reader Message) {}
byte[] 二进制消息 public void handleMessage(byte[] data) {}
ByteBuffer 二进制消息 public void handleMessage(ByteBuffer data) {}
byte[],boolean 二进制消息片段 public void handleMessage(byte[] data,boolean isLast) {}
ByteBuffer,boolean 二进制消息片段 public void handleMessage(ByteBuffer data,boolean isLast) {}
PongMessage Pong消息 public void handleMessage(PongMessage Message) {}
除了接收上面的消息类型,还可以接收java定义的类,但是要先为类型定义好解码器
解码器:Decoder
解码器接口类型
Decoder.Text<T> T转换成String类型 T decode(String raw)
Decoder.TextStream<T> T转换成Writer T decode(Reader raw)
Decoder.Binar<T> T转换成ByteBuffer T decode(ByteBuffer raw)
Decoder.BinaryStream<T> T转换成OutputStream T decode(InputStream raw)
WebSocket 消息处理有非常严格的限定,每个注解式端点最多只有一个消息处理方法处理每种本地消息类型。
作者:Mark_XC
来源:CSDN
原文:https://blog.csdn.net/Mark_Ch...
版权声明:本文为博主原创文章,转载请附上博文链接!