【问题标题】:Metro with jax-ws override endpoint addressMetro 与 jax-ws 覆盖端点地址
【发布时间】:2011-10-17 09:22:27
【问题描述】:

我正在使用带有 jax-wsMetro 创建一个 Web 服务客户端,并且我想覆盖端点地址。

使用 2.11.1 中的以下示例。 BindingProvider.ENDPOINT_ADDRESS_PROPERTY 我可以这样做: http://metro.java.net/guide/How_to_invoke_and_endpoint_by_overriding_endpoint_address_in_the_WSDL.html

//Create service and proxy from the generated Service class.
HelloService service = new HelloService();
HelloPort proxy = service.getHelloPort();

((BindingProvider)proxy).getRequestContext().put(BindingProvider.ENDPOINT_ADDRESS_PROPERTY,
                                                    "http://new/endpointaddress");

proxy.sayHello("Hello World!");

但我不明白为什么我不能使用 service.getHelloPort().sayHello("Hello World!") 而不是 proxy.sayHello("Hello World! ") 如示例所示。如果我这样做了,Web 服务客户端将使用它的默认端点地址,而不是我想要使用的那个。

看起来我每次调用 getHelloPort()

时都会得到一个新的 HelloPort 实例

谁能解释一下?

【问题讨论】:

  • 你的代码是什么?你如何覆盖端点地址?
  • 更新了代码示例。我在别处也得到了一些指示。 System.out.println(service.getHelloPort() == service.getHelloPort()) 打印出错误,所以看起来我真的为每个 getHelloPort() 调用获取了一个新实例

标签: java jax-ws


【解决方案1】:

这些之间几乎没有(阅读:没有)区别:

service.getHelloPort().sayHello("Hello World");

HelloPort proxy = service.getHelloPort();
proxy.sayHello("Hello World!");

service.getHelloPort() 调用将始终返回一个新的代理/端口实例。因此,每当您修改给定端口对象的请求上下文时,该修改对于特定端口实例都是本地的。

一般来说,只要您不修改请求/响应上下文,您返回的端口实例是可重用且线程安全的。对于您发布的代码示例,它正在修改请求上下文以设置端点地址,因此建议您每次需要一个新端口对象时获取一个新对象,或者至少为每个需要的线程获取一个新对象一。 (threadlocal 是你的朋友)

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2012-09-22
    • 1970-01-01
    • 1970-01-01
    • 2022-07-15
    • 2014-12-31
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多