我现在使用 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
关于java - 用于动态端点的 Apache CXF 客户端,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3018883/