[英]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.