我使用CXF 3.1.5,我试图使它与代理一起使用。如果没有用户名和密码的代理,那么它的工作原理;如果有代理的用户名和密码,那么它不起作用。这里是我的代码:
为CXF设置ProxyAuthorizationPolicy httpConduit不起作用
//to create my own http conduit
bus.setExtension(new TLSAndProxySupportedHTTPConduitFactory(settings, HTTPConduitFactory.class);
//to get wsdl definition
Definition definition = bus.getExtension(WSDLManager.class).getDefinition(uri);
TLSAndProxySupportedHTTPConduitFactory实现HTTPConduitFactory,并将创建一个TLSAndProxySupportedHTTPConduit延伸URLConnectionHTTPConduit,在TLSAndProxySupportedHTTPConduit,这里是代理设置相关的代码:
//HTTPClientPolicy settings works
HTTPClientPolicy httpClientPolicy = new HTTPClientPolicy();
httpClientPolicy.setProxyServer(proxy.getHostName());
httpClientPolicy.setProxyServerPort(proxy.getPort());
this.setClient(httpClientPolicy);
if (proxy.getUserName() != null) {
//ProxyAuthorizationPolicy settings doesn't work
this.getProxyAuthorization().setUserName(proxy.getUserName());
this.getProxyAuthorization().setPassword(proxy.getPassword());
}
请记住,如果代理没有用户名和密码,一切正常,如果加载WSDL定义的目标URL开始于https(https需要我),代理不起作用。如果它是以http开头的,那么带有用户名和密码的代理运行良好。