代理服务器的Axis2 NTLM身份验证

时间:2011-01-13 13:42:28

标签: java authentication proxy axis2 ntlm

在需要NTLM身份验证的http代理服务器上验证Axis2(版本1.4)客户端的正确方法是什么?

我正在使用以下代码提供代理凭据,但身份验证仍然失败(请参阅最后的详细信息):

Options options = serviceStub._getServiceClient().getOptions();
options.setProperty(HTTPConstants.CHUNKED, false);
options.setProperty(HTTPConstants.PROTOCOL_VERSION, HTTPConstants.HEADER_PROTOCOL_10);

ProxyProperties proxyProperties = new ProxyProperties();
proxyProperties.setProxyName("123.123.123.123");
proxyProperties.setProxyPort(8080);
proxyProperties.setUserName("myUser@www.example.org");
proxyProperties.setPassWord("1234");
proxyProperties.setDomain("");
options.setProperty(HTTPConstants.PROXY, proxyProperties);

凭借完全相同的凭据,一个web浏览器,如Firefox,能够通过代理,所以我假设,代理服务器已正确设置。但是,对于Axis2客户端,身份验证失败(HTTP状态代码为“407 Proxy Authentication Required”)。

进一步详情: 我使用网络嗅探器比较了来自firefox和我的客户端的网络流量。主要的区别似乎是,axis2客户端正在为ntlm挑战发送空响应。

是否有人使用NTLM在http代理服务器上成功进行了身份验证?你能给我一个代码示例吗?

1 个答案:

答案 0 :(得分:1)

我无法解决此问题(使用Axis 2)。不想把这个归咎于Axis2强硬。也许我做错了什么但是无法弄明白,即使经过几个小时的尝试,调试和阅读文档。

但是当我用完选项时,我不得不寻找其他选择。另一种选择是以替代SOAP-Frameworks的形式出现的。 java存在相当多的SOAP框架。我知道Axis2,CXF和JAX-WS。

而不是Axis2我现在使用JAX-WS。替换框架是一个直接的过程。替换的一个很好的副作用是,我摆脱了巨大的依赖树,Axis2自带了。 JAX-WS是J6EE的一部分,因此不需要导入其他依赖项。

此时我只在客户端进行了更换。服务器仍然使用Axis2。到目前为止,这种组合效果很好,但我仍然计划最终在服务器端替换Axis2。

总而言之:如果您不使用Axis2的特殊功能,我认为,JAX-WS是更好的选择。