【问题标题】:Android 6.0 HTTPClient issue with LG G3 phoneLG G3 手机的 Android 6.0 HTTPClient 问题
【发布时间】:2016-03-28 12:23:47
【问题描述】:

您好,我正在使用 DefaultHTTPClient 类来创建 http 请求。

当前代码 execute() 方法适用于所有手机,包括 Nexus 和三星 Android 6.0。

但是当我在装有 Android 6.0 更新的 LG 手机上进行测试时,我收到如下所示的错误

 Java.lang.ArrayIndexOutOfBoundsException: length=1; index=1
03-28 17:21:17.040: E/xx_SDK(14035):  at org.apache.http.impl.auth.DigestScheme.isGbaScheme(DigestScheme.java:210)
03-28 17:21:17.040: E/xx_SDK(14035):  at org.apache.http.impl.auth.DigestScheme.processChallenge(DigestScheme.java:176)
03-28 17:21:17.040: E/xx_SDK(14035):  at org.apache.http.impl.client.DefaultRequestDirector.processChallenges(DefaultRequestDirector.java:1097)
03-28 17:21:17.040: E/xx_SDK(14035):  at org.apache.http.impl.client.DefaultRequestDirector.handleResponse(DefaultRequestDirector.java:980)
03-28 17:21:17.040: E/xx_SDK(14035):  at org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:490)
03-28 17:21:17.040: E/xx_SDK(14035):  at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:560)
03-28 17:21:17.040: E/xx_SDK(14035):  at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:492)
03-28 17:21:17.040: E/xx_SDK(14035):  at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:470)
03-28 17:21:17.040: E/xx_SDK(14035):  at java.lang.Thread.run(Thread.java:818)

我试图了解什么问题,它谈到了摘要身份验证。

我从 Android 6.0 知道他们已经删除了 Apache Http 客户端,现在使用 HTTPUrlConnection 类

我尝试将 "org.apache.http.legacy.jar" 文件从 sdk 复制到我的项目 lib 文件夹。

但我仍然面临同样的错误日志。我希望有人可以帮助我解决这个问题。

请按原样查找应用程序代码:

HttpParams params = new BasicHttpParams();
ClientConnectionManager connectionManager = null;
try {
KeyStore trustStore = KeyStore.getInstance(KeyStore.getDefaultType());
trustStore.load(null, null);
SchemeRegistry registry = new SchemeRegistry();
SSLSocketFactory sf = new MySSLSocketFactory(trustStore);
sf.setHostnameVerifier(SSLSocketFactory.BROWSER_COMPATIBLE_HOSTNAME_VERIFIER);     
registry.register(new Scheme("http", PlainSocketFactory.getSocketFactory(), 80));
registry.register(new Scheme("https", sf, 443));
connectionManager = new SingleClientConnManager(params, registry);
}
catch (Exception e)
 {
  Log.e(TAG, Log.getStackTraceString(e));
 }

 ConnManagerParams.setTimeout(params, mTimeOut);
 HttpConnectionParams.setSoTimeout(params, mTimeOut);
 HttpConnectionParams.setConnectionTimeout(params, mTimeOut);
 HttpConnectionParams.setTcpNoDelay(params, true);

 DefaultHttpClient client = new DefaultHttpClient(connectionManager, params);

client.getCredentialsProvider().setCredentials(new AuthScope(host,port),
new UsernamePasswordCredentials(userID,passowrd));

client.setRedirectHandler(new RedirectHandler() {
@Override
public boolean isRedirectRequested(HttpResponse response, HttpContext context) {
}
@Override
public URI getLocationURI(HttpResponse response, HttpContext context) throws ProtocolException {
}

try {
HttpGet httpget = new HttpGet(url);
HttpResponse response = client.execute(httpget);  // issue occur here

【问题讨论】:

    标签: java android eclipse apache-httpclient-4.x android-6.0-marshmallow


    【解决方案1】:

    遇到了类似的问题,我正在尝试修复并添加到another question


    我今天遇到了类似的问题,刚开始使用HttpClient for Android

    1. 将依赖项 compile 'org.apache.httpcomponents:httpclient-android:4.3.5.1' 添加到 build.gradle。
    2. new DefaultHttpClient() 替换为HttpClientBuilder.create().build()

    您可能需要在代码的其他部分进行一些其他小的重构,但这应该很简单。

    【讨论】:

    • 我根据 Android 6.0 规范使用了该库。使用库“org.apache.http.legacy.jar”。我看到的是它发送http请求。服务器以 401 代码响应,我们再次使用摘要身份验证发送。如果您看到错误日志,我觉得 Digest 参数有些问题。同时你能告诉我如何使用你的新代码。我无法理解如何更改 DefaultClient。你的第二点不清楚
    • 我也在使用旧版 jar,但仍然仅在 LG G5 和 LG G3 上出现错误。我没有看到示例代码,所以我假设您在某个地方使用 apache 库中的 DefaultHttpClient。如果添加新的依赖项,则需要在发出请求之前更新使用DefaultHttpClient 的代码以使用HttpClientBuilder。这将使用httpclient-android 中的新代码,并且应该正确处理摘要参数。
    • 非常感谢您的 cmets。我真的很高兴看到你的支持。这对我来说是一个非常关键的问题。根据您的评论,我已经更新了我的应用程序代码。现在你可以看到上面的代码了。请支持我如何根据 HttpClientBuilder 更改此代码。
    • 我能够使用您给我的答案和提到的库来纠正 lg 电话错误。一切正常,直到我看到 HTTPS 连接不起作用。使用 HTTPS 时,我无法使应用程序正常工作。因此我为它添加了一个新问题..stackoverflow.com/questions/36677494/…。请帮助我使用新库纠正 ssl 问题
    【解决方案2】:

    试一试,我在运行 6.0.1 的 MotoX 上遇到了类似的问题,但这似乎对我有用。

     protected static final int HTTP_JSON_TIMEOUT_CONNECTION = 20000;
     protected static final int HTTP_JSON_TIMEOUT_SOCKET = 20000;
    
     CloseableHttpResponse response = null;
       try {
            UserPrefs.clearCacheFolder(mContext.getCacheDir());
            CloseableHttpClient httpClient = getApacheHttpClient();
            HttpPost httpPost = getHttpPost( invocation);
    
           response = httpClient.execute(httpPost);
        }catch (Exception e){
            e.printStackTrace();
        }
    
    
        protected CloseableHttpClient getApacheHttpClient(){
        try {
            // Socket config
            SocketConfig socketConfig = SocketConfig.custom()
                    .setSoTimeout(HTTP_JSON_TIMEOUT_SOCKET)
                    .build();
            // Auth
            CredentialsProvider credentialsProvider = new BasicCredentialsProvider();
            credentialsProvider.setCredentials(new AuthScope(URL, PORT, null, "Digest"),
                    new UsernamePasswordCredentials(USERNAME,DIGEST_PASSWORD));
            // Build HttpClient
            return HttpClients.custom()
                    .setDefaultSocketConfig(socketConfig)
                    .setDefaultCredentialsProvider(credentialsProvider)
                    .build();
        }catch (Exception e) {
            Log.i("ApacheHttpClientHelper", "ERROR >> "+e.getMessage());
            return null;
        }
    }
    

    也将它粘贴到依赖项下的 gradle 中

      compile group: 'org.apache.httpcomponents' , name: 'httpclient-android' , version: '4.3.5.1'
    

    【讨论】:

      猜你喜欢
      • 2015-11-29
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2021-11-22
      相关资源
      最近更新 更多