我正在使用ksoap2 3.6。
我正在尝试访问使用NTLM保护的soap Web服务。我找到了ksoap2-extra-ntlm-3.6.0.jar文件并将其添加到我的项目中,认为这是我的保存优雅。
NtlmTransport ntlmTransport = new NtlmTransport(BASE_URL);
ntlmTransport.setCredentials(USERNAME, PASSWORD, DOMAIN, "");
ntlmTransport.call(name_space + method_name, envelope);
但是,我收到了未经授权的401响应代码。我已经通过.NET和基于浏览器的身份验证方法验证了我的用户名,密码和域名,所以我知道这些是正确的。
问题:我如何实际验证并通过401代码?
感谢。
答案 0 :(得分:1)
这对我有用。
由于ksoap2是开源的,我偷看了NtlmTransport的代码并以下列方式改变了调用方法。
我删除了:
BasicHttpParams httpParameters = new BasicHttpParams();
HttpConnectionParams.setConnectionTimeout(httpParameters, this.timeout);
DefaultHttpClient client = new DefaultHttpClient(httpParameters);
client.getAuthSchemes().register("ntlm", new NtlmTransport.NTLMSchemeFactory());
NTCredentials credentials = new NTCredentials(this.user, this.password, this.ntWorkstation, this.ntDomain);
client.getCredentialsProvider().setCredentials(AuthScope.ANY, credentials);
并用以下代码替换该代码:
NTCredentials ntCredentials = new NTCredentials(user, password, ntWorkstation, ntDomain );
CredentialsProvider credentialsProvider = new BasicCredentialsProvider();
credentialsProvider.setCredentials(new AuthScope(AuthScope.ANY), ntCredentials);
HttpClientBuilder clientBuilder = HttpClientBuilder.create();
clientBuilder.useSystemProperties();
clientBuilder.setDefaultCredentialsProvider(credentialsProvider);
CloseableHttpClient client = clientBuilder.build();
我用try ... finally块封装了执行和响应代码,以关闭finally块中的客户端。现在就像一个魅力。
我添加了
compile group: 'org.apache.httpcomponents' , name: 'httpclient-android' , version: '4.3.5.1'
到我的gradle文件。
认为有人可能会受益。
感谢。