HttpClient 4.2,基本身份validation和AuthScope
我有一个应用程序连接到需要基本身份validation的站点。 这些站点在运行时提供,在编译时不知道。
我正在使用HttpClient 4.2。
我不确定下面的代码是否应该如何指定基本身份validation,但文档会建议它。 但是,我不知道在AuthScope
的构造函数中传递什么。 我原以为null参数意味着所提供的凭据应该用于所有URL,但它会抛出NullPointerException
,所以显然我错了。
m_client = new DefaultHttpClient(); UsernamePasswordCredentials credentials = new UsernamePasswordCredentials(m_userName, m_password); ((DefaultHttpClient)m_client).getCredentialsProvider().setCredentials(new AuthScope((HttpHost)null), credentials);
您正在使用AuthScope.ANY: http ://hc.apache.org/httpcomponents-client-ga/httpclient/apidocs/org/apache/http/auth/AuthScope.html
尝试这个:
final HttpClient client = new HttpClient(); client.getParams().setAuthenticationPreemptive(true); client.getState().setCredentials(AuthScope.ANY, new UsernamePasswordCredentials(user.getUsername(), user.getPassword())); final GetMethod method = new GetMethod(uri); client.executeMethod(method);
至少从版本4.2.3(我猜版本3.X之后),接受的答案不再有效。 相反,做一些事情:
private HttpClient createClient() { HttpParams params = new BasicHttpParams(); HttpProtocolParams.setContentCharset(params, "UTF-8"); Credentials credentials = new UsernamePasswordCredentials("user", "password"); DefaultHttpClient httpclient = new DefaultHttpClient(params); httpclient.getCredentialsProvider().setCredentials(AuthScope.ANY, credentials); return httpclient; }
AuthScope.ANY
的JavaDoc说在HttpClient的未来版本中,将停止使用此参数 ,因此使用它需要您自担风险。 更好的选择是使用AuthScope
定义的构造函数之一。
有关如何提出请求抢先的讨论,请参阅:
使用Apache HttpClient进行抢占式基本身份validation4
- 为什么这个简单的SOAP客户端不工作(org.apache.http)?
- Apache Commons HttpClient是否支持GZIP?
- 如何从apache httpclient 4中禁用默认请求标头?
- 从HttpClient 3转换为4
- 使用Apache的HTTP客户端时,将HTTP响应作为String的推荐方法是什么?
- 如何强制Commons HTTPClient 3.1仅对HTTPS使用TLS 1.2?
- 使用Apache commons HttpClient时,如何覆盖请求中的“Host”头
- 从Commons HttpClient迁移到HttpComponents Client
- HttpClient支持多种TLS协议