[英]Decode “send” message from WebSocket with Java
我正在尝试编写自己的 WebSocket 服务器。
我知道有一些框架可以解决这个问题,但我想学习,所以我自己做:)
我的 JavaScript 客户端当前对onOpen
做出反应,所以我认为握手是有效的并且连接已经建立。
现在的问题:
我的 Java 服务器使用一个选择器线程来读取通道。
如果我在客户端的 WebSocket 对象上执行*.send("test message")
,则我的服务器无法解码字节数组。
我没有找到关于使用的编码/解码技术的信息,所以我尝试了很多版本来解码。
例如:
new String(Base64.decodeBase64(buffer.array()))
要么
Charset set = Charset.forName("UTF-8");
new String(Base64.decodeBase64(set.decode(buffer).toString()))
消息完全从Channel读入ByteBuffer,所以我不认为这是问题所在。
谁能帮我?
好的,这篇文章可以帮助我向客户端发送数据。 这工作正常:)
但我不明白如何解码从客户端收到的数据:(
在客户处,我只发送一封信
socket.send("x");
服务器收到 7 个字节???
ByteBuffer buffer = ByteBuffer.allocate(8192);
int read = client.getInputStream().read(buffer2.array());
System.out.println("read: " + read);
// read: 7
for (int i = 0; i < read; i++) {
int j = buffer.get(i) & 0xff;
System.out.println("i: " + i + " => " + j + "=>" + new BigInteger(j + "").toString(2));
}
//i: 0 => 129=>10000001
//i: 1 => 129=>10000001
//i: 2 => 195=>11000011
//i: 3 => 235=>11101011
//i: 4 => 4=>100
//i: 5 => 96=>1100000
//i: 6 => 187=>10111011
如果我这样做
secondByte AND 0111 1111
(i: 1) 的结果是“1”我认为这意味着只有一个字节的数据。 那为什么 read 是 7 ???
至于你的第二个问题 - 从客户端到服务器的数据总是被屏蔽,正如我在上面的链接中所解释的那样。 掩码占用 4 个字节。
所以,实际数据的长度确实是 1。只有第二个字节的最后 7 位说明了长度 - 第一位没有,所以只需丢弃那个以获得000 0001
即1
。
在这种情况下,字节分类如下:
要获取数据,请计算data XOR masks[data_index MOD 4]
,即在这种情况下为187 XOR 195
,即120
- x
的字符代码。
private String decodeMessage(){
try {
byte[] data = new byte[1024];
int size = in.read(data);
if (size == -1) return null;
byte[] decoded = new byte[size-6];
byte[] key = new byte[]{ data[2], data[3], data[4], data[5] };
for (int i = 0; i < size-6; i++) {
decoded[i] = (byte) (data[i+6] ^ key[i & 0x3]);
}
return new String(decoded, "UTF-8");
}catch (IOException ex){
ex.printStackTrace();
}
return "ping";
}
这段代码可能不好,但对我有用
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.