我想使用 NTLM 为 DefaultHttpClient 实现抢先式身份验证。我从Dan Hounshell找到了一个库,它可以正常进行身份验证。
但我无法弄清楚如何通过抢先身份验证来实现这一点。我用这个很酷的答案找到了使用 Apache HttpClient 4 的 Preemptive Basic authentication问题:
UsernamePasswordCredentials creds = new UsernamePasswordCredentials(username, password);
HttpRequest request = ...
request.addHeader(new BasicScheme().authenticate(creds, request));
不适合我的问题,但一个好主意。所以我尝试使用NTLMSchemeFactory
创建一个新实例AuthScheme
with 给了我这个authenticate
功能。
NTCredentials ntc = new NTCredentials("example.com/user:pwd");
httpPost.addHeader(new NTLMScheme(new JCIFSEngine()).authenticate(ntc, httpPost));
当这个函数被调用时,我会得到一个异常:
org.apache.http.auth.AuthenticationException:意外状态:未初始化
我该如何解决?
POST /login/ HTTP/1.1
Content-Length: 21
Content-Type: application/x-www-form-urlencoded
Host: example.com
Connection: Keep-Alive
data=...
HTTP/1.1 401 Unauthorized
Content-Type: text/html
Server: Microsoft-IIS/7.5
WWW-Authenticate: Negotiate
WWW-Authenticate: NTLM
X-Powered-By: ASP.NET
Date: Wed, 12 Dec 2012 14:36:26 GMT
Content-Length: 1344
Much data...
POST /login/ HTTP/1.1
Content-Length: 21
Content-Type: application/x-www-form-urlencoded
Host: example.com
Connection: Keep-Alive
Authorization: NTLM AAABBBCCC...FFF==
data=...
我认为第一个请求绝对没用。