gpt4 book ai didi

java - 使用 Java 进行 RPC 和 UniData 模拟

转载 作者:行者123 更新时间:2023-12-01 09:09:38 24 4
gpt4 key购买 nike

我正在尝试为 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() 实际上试图从连接中检索什么。虽然我可以看到反编译的代码,但这是我理解它试图解析的内容的最佳尝试。我正在看this websitethis answer :

  • 0xFF = 00000000 00000000 00000000 11111111(表示 32 位 int 值)

  • value & 0xFF = 将除前 8 位之外与 1 重叠的所有 0 替换为零

  • 如果 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);
}

我得到的输出:11597109112108101

因此,所讨论的方法很可能是在建立 RPC 连接时寻找一些格式良好的 header 进行同步。我试图看看这个website了解我应该作为服务器响应的一部分传递哪种 header ,以便 readHeaderLength() 方法有利于通信,但尚未找到明确的答案。

  • 我对 readHeaderLength() 方法工作原理的理解正确吗?
  • 我是否正确推断它很可能正在寻找 RPC header ?

最佳答案

headerBuffer 字节数组在数组索引位置 4、5、6、7 中包含一个 4 字节 int 值。readHeaderLength 方法只是使用位移操作将这 4 个字节数组字节值转换为实际的 int 类型值。

编辑:很可能这是来自套接字的输入流的 header 长度,在 header 开始流的主体之后。我建议更多地研究该代码如何知道“ header 长度”值存储在索引位置 4、5、6、7 中。这是在 RPC header 中定义的吗?

关于java - 使用 Java 进行 RPC 和 UniData 模拟,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41001793/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com