我正在尝试为 RPC 服务器编写一个模拟器,以便可以使用 UniData Java 库。如果我反编译他们的 api,我会看到这段代码。
private byte[] headerBuffer;
private int readHeaderLength() {
return ((this.headerBuffer[4] & 0xFF) << 24) +
((this.headerBuffer[5] & 0xFF) << 16) +
((this.headerBuffer[6] & 0xFF) << 8) +
((this.headerBuffer[7] & 0xFF) << 0);
}
headBuffer 属性填充了如下内容:
final Socket socket = new Socket("127.0.0.1", 31438);
final DataInputStream dataIn = new DataInputStream(socket.getInputStream());
dataIn.readFully(this.headerBuffer);
通过挖掘,这部分代码似乎负责初始化与某个服务器的 RPC 连接。
为了模拟这一点,我创建了一个侦听此端口的服务器,并打开输出流,如下所示:
@Override
public void run() {
try {
final DataInputStream dataIn = new DataInputStream(socket.getInputStream());
final DataOutputStream dataOut = new DataOutputStream(socket.getOutputStream());
final String connectionResponse = "SIMULATED_CONNECTION";
dataOut.write(connectionResponse.getBytes());
System.out.println("#### message sent");
while (true) {
final byte[] data = new byte[1024];
dataIn.readFully(data);
final String input = new String(data);
if (input == null || input.equals(".")) {
System.out.println("### the input line is " + input);
break;
}
System.out.println("## received message " + input);
}
} catch (final IOException e) {
System.out.println("Error handling request : " + e.getMessage());
} finally {
try {
socket.close();
} catch (final IOException e) {
System.out.println("## cant close socket " + e.getMessage());
}
}
}
但是,我一生都无法弄清楚 readHeaderLength() 实际试图从连接中检索什么。虽然我可以看到反编译的代码,但这是我理解它试图解析的内容的最佳尝试。我正在看这个网站和这个答案:
0xFF = 00000000 00000000 00000000 11111111(表示 32 位 int 值)
value & 0xFF = 将所有与 1 重叠的 0 替换为零,除了前 8 位
如果 this.headerBuffer[5] 评估为某个值,则可能产生 ... 01100100 00000101 & ...00000000 11111111 = 00000000 00000101
当 (this.headerBuffer[5] & 0xFF) 计算时,<< 16 将在右侧添加 16 个零。
那么 this.headerBuffer[]实际包含什么?
如果我写一些简单的东西,例如:
final String data = "sample";
final byte[] bytes = data.getBytes();
for (final byte bit : bytes) {
System.out.println(bit);
}
我得到的输出:115 97 109 112 108 101
因此,所讨论的方法很可能是在建立 RPC 连接时寻找一些格式良好的标头以进行同步。我试图查看这个网站以了解我应该传递什么样的标头作为我的服务器响应的一部分,以便 readHeaderLength() 方法有利于通信,但尚未找到明确的答案。
- 我对 readHeaderLength() 方法如何工作的理解是否正确?
- 我是否正确推断它最有可能在寻找 RPC 标头?