gpt4 book ai didi

java - 通过互联网发送对象并调用它的方法

转载 作者:行者123 更新时间:2023-11-30 02:50:32 25 4
gpt4 key购买 nike

我有一个 java web 服务器,我做了它,以便服务器通过发送回包含“execute”方法的 java 对象来响应某个 http* 请求。

我希望能够执行远程对象的方法。

  • 我无法使用反射,因为我不发送类,考虑创建一个具有相同方法+包名称的本地类,以便我可以尝试 object.getClass()

  • 我不想将要发送的对象的整个代码块放入 toString() 中。 (覆盖)

  • 我无法转换到接口(interface)。

我还在考虑制作一个 .jar 库,其中包含将在服务器上创建并在客户端上访问的类文件的定义,这如何工作?

我找不到与此相关的其他问题,所以我将其留在这里。

编辑:

  • 我使用 URLConnection 与 servlet 进行通信,servlet 在服务器上创建对象的实例,然后使用 ObjectOutputStream 以及客户端上的 ObjectInputStream 将其发送到客户端以获取它。

  • 寻找 RMI 的替代品,如果没有,我会查找一些 RMI 教程。

  • 关于我选择不首先使用 RMI:也许我不想每次都在客户端-服务器之间建立连接,也许我想反序列化对象并检查/调用它的方法。

最佳答案

如果要将序列化对象从一个 java 虚拟机(java 进程)“发送”到另一个,则需要在两端都存在 .class 文件。如果您决定继续采用当前的方法,您将需要以下内容:

  • 您的客户端必须是 Java,或者能够运行 Java,并且具有与其在本地接收的对象相对应的 .class 文件,或者必须在访问它们之前从服务器下载它们。

  • 您必须以某种方式将序列化对象流封装在 HTTP 中。 HTTP 是一种用于请求和发送网页的协议(protocol)。它与 Java 的序列化协议(protocol)不兼容(例如,它包含额外的 header ),并且您需要将 Java 序列化包装在 HTTP 有效负载中才能按您预期的方式工作。

  • 当您发送序列化对象时,您实际上是在发送“对象图”(该对象以及通过导航其字段可访问的所有对象)。这最终可能会导致效率低下。因此,序列化可能不是您的最佳答案。

使用其他机制要容易得多:

  • 如果您避免使用 HTTP,则无需额外的包装器。编写一个在连接时接收和发送序列化对象的简单服务器比在传统 Java Web 应用程序中编写 HTTP 包装器要容易和高效得多(Java 应用程序服务器往往需要大量资源)。

  • 考虑使用 Kryo或其他 Java 序列化/网络库 - 它们带有内置服务器,并允许对发送的内容进行非常细粒度的控制。

  • Java 具有对 RMI(“远程方法调用”)的内置支持。这似乎就是您真正想要实现的目标。您不再需要知道对象是本地的还是远程的 - 它们看起来工作相同,并且所有必需的网络和序列化都是在幕后完成的。阅读 all about it .

关于java - 通过互联网发送对象并调用它的方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38802596/

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