繁体   English   中英

用于动态端点的 Apache CXF 客户端

[英]Apache CXF Client for Dynamic Endpoints

我现在使用 Apache CXF 作为 .NET 服务的 Web 服务客户端来绕过 NTLM 身份验证。 它工作得很好,但我想知道为什么我似乎无法设置 Web 服务目标端点。 出于某种奇怪的原因,CXF 似乎希望在运行时使用 WSDL - 不确定。 它从 WSDL 获取物理端点,我猜它在测试环境中工作正常,但在部署时它肯定会改变。

下面是一些代码来演示:

        MyWebServices service = new MyWebServices ();
        MyWebServicesSoap port = service.getMyWebServicesSoap12();

        // Turn off chunking so that NTLM can occur
        Client client = ClientProxy.getClient(port);
        HTTPConduit http = (HTTPConduit) client.getConduit();
        HTTPClientPolicy httpClientPolicy = new HTTPClientPolicy();
        httpClientPolicy.setConnectionTimeout(36000);
        httpClientPolicy.setAllowChunking(false);
        http.setClient(httpClientPolicy);

        port.doSomethingUseful();

同样,在 CXF 客户端 API 中没有任何地方可以让我设置服务端点。 反正我看不到。 在这种情况下,目标是http://localhost/integration/webservices/mywebservices.asmx ,但我可以在任何地方。 当然,这个行人问题以某种方式解决了?

请尝试以下操作:

MyWebServicesSoap port = service.getMyWebServicesSoap12();
BindingProvider provider = (BindingProvider) port;
provider.getRequestContext().put(BindingProvider.ENDPOINT_ADDRESS_PROPERTY, endpoint); 

或者, MyWebServices可能有其他 getXXX 方法,这些方法采用 WSDL 位置的 URL

在 cxf 2.6.1 中工作

Client client = ClientProxy.getClient(port);
client.getRequestContext().put(Message.ENDPOINT_ADDRESS, "http://some-valid-endpoint") ;

这对我有用。

String customerEndPoint = "https://localhost:8080/customerService/v1"

customerWebService = service.getCustomerWebServicePort();

((BindingProvider) customerWebService).getRequestContext()
                        .put(BindingProvider.ENDPOINT_ADDRESS_PROPERTY,
                                customerEndPoint);

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM