Модераторы: javastic
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Проблема с httpcomponents в Android 
:(
    Опции темы
redradist
Дата 31.7.2017, 01:29 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 6
Регистрация: 31.7.2017

Репутация: нет
Всего: нет



Всем привет,

Вообщем ситуация следующая.
Написал тестовое приложение по работе с Jira-ой на базе Atlassian Rest Client на Java.
На Java пример заработал но при портировании на Android естественно возникли нюансы ...

Последнее на чем я завис это ошибка:

Код

FATAL EXCEPTION: main
Process: com.example.redra.newtoggletimer, PID: 18803
java.lang.NoSuchFieldError: No field INSTANCE of type Lorg/apache/http/message/BasicLineFormatter; in class Lorg/apache/http/message/BasicLineFormatter; 
or its superclasses (declaration of 'org.apache.http.message.BasicLineFormatter' appears in /system/framework/org.apache.http.legacy.boot.jar)
                                                                                      at org.apache.http.impl.nio.codecs.DefaultHttpRequestWriterFactory.<init>(DefaultHttpRequestWriterFactory.java:52)
                                                                                      at org.apache.http.impl.nio.codecs.DefaultHttpRequestWriterFactory.<init>(DefaultHttpRequestWriterFactory.java:56)
                                                                                      at org.apache.http.impl.nio.codecs.DefaultHttpRequestWriterFactory.<clinit>(DefaultHttpRequestWriterFactory.java:46)
                                                                                      at org.apache.http.impl.nio.conn.ManagedNHttpClientConnectionFactory.<init>(ManagedNHttpClientConnectionFactory.java:75)
                                                                                      at org.apache.http.impl.nio.conn.ManagedNHttpClientConnectionFactory.<init>(ManagedNHttpClientConnectionFactory.java:83)
                                                                                      at org.apache.http.impl.nio.conn.ManagedNHttpClientConnectionFactory.<clinit>(ManagedNHttpClientConnectionFactory.java:64)
                                                                                      at com.atlassian.httpclient.apache.httpcomponents.ApacheAsyncHttpClient.<init>(ApacheAsyncHttpClient.java:175)
                                                                                      at com.atlassian.httpclient.apache.httpcomponents.ApacheAsyncHttpClient.<init>(ApacheAsyncHttpClient.java:123)
                                                                                      at com.atlassian.httpclient.apache.httpcomponents.DefaultHttpClientFactory.doCreate(DefaultHttpClientFactory.java:68)
                                                                                      at com.atlassian.httpclient.apache.httpcomponents.DefaultHttpClientFactory.create(DefaultHttpClientFactory.java:35)
                                                                                      at com.atlassian.jira.rest.client.internal.async.AsynchronousHttpClientFactory.createClient(AsynchronousHttpClientFactory.java:63)
                                                                                      at com.atlassian.jira.rest.client.internal.async.AsynchronousJiraRestClientFactory.create(AsynchronousJiraRestClientFactory.java:35)
                                                                                      at com.atlassian.jira.rest.client.internal.async.AsynchronousJiraRestClientFactory.createWithBasicHttpAuthentication(AsynchronousJiraRestClientFactory.java:42)
                                                                                      at com.example.redra.newtoggletimer.MainActivity$1$1.onFinish(MainActivity.java:48)
                                                                                      at android.os.CountDownTimer$1.handleMessage(CountDownTimer.java:127)
                                                                                      at android.os.Handler.dispatchMessage(Handler.java:105)
                                                                                      at android.os.Looper.loop(Looper.java:156)
                                                                                      at android.app.ActivityThread.main(ActivityThread.java:6577)
                                                                                      at java.lang.reflect.Method.invoke(Native Method)
                                                                                      at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:941)
                                                                                      at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:831)


Нашел несколоко решений на StackOverflow но ничего не помогло и того что людям помогало
Встречал ли кто-то подобную ошибку и как ее побороть уже полдня мучаюсь ??

Gradle файл:

Код

apply plugin: 'com.android.application'

android {
    useLibrary 'org.apache.http.legacy'
    compileSdkVersion 25
    buildToolsVersion "25.0.2"
    defaultConfig {
        applicationId "com.example.redra.newtoggletimer"
        minSdkVersion 15
        targetSdkVersion 25
        versionCode 1
        versionName "1.0"
        testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
    }
    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        }
    }
    configurations.all {
        resolutionStrategy.force 'com.google.code.findbugs:jsr305:1.3.9'
    }
    packagingOptions {
        pickFirst  'META-INF/license.txt'
        exclude 'META-INF/DEPENDENCIES.txt'
        exclude 'META-INF/LICENSE.txt'
        exclude 'META-INF/NOTICE.txt'
        exclude 'META-INF/NOTICE'
        exclude 'META-INF/LICENSE'
        exclude 'META-INF/DEPENDENCIES'
        exclude 'META-INF/notice.txt'
        exclude 'META-INF/license.txt'
        exclude 'META-INF/dependencies.txt'
        exclude 'META-INF/ASL2.0'
        exclude 'META-INF/jersey-module-version'
        exclude 'org/apache/http/nio/client/version.properties'
        exclude 'org/apache/http/version.properties'
        exclude 'org/apache/http/nio/version.properties'
        exclude 'org/apache/http/entity/mime/version.properties'
    }
    dexOptions {
        preDexLibraries = false
        additionalParameters=['--core-library']
    }
}

dependencies {
    compile fileTree(dir: 'libs', include: ['*.jar'])
    androidTestCompile('com.android.support.test.espresso:espresso-core:2.2.2', {
        exclude group: 'com.android.support', module: 'support-annotations'
    })
    compile 'com.android.support:appcompat-v7:25.3.1'
    compile 'com.android.support.constraint:constraint-layout:1.0.2'
    compile 'com.android.support:design:25.3.1'
    compile 'com.atlassian.fugue:fugue:2.6.1'
    compile 'org.slf4j:slf4j-simple:1.6.4'
    compile 'com.atlassian.jira:jira-rest-java-client-core:4.0.0'
    compile 'com.atlassian.jira:jira-rest-java-client-api:4.0.0'
    compile 'commons-logging:commons-logging:1.2'
    compile 'commons-net:commons-net:3.6'
    compile 'org.apache.httpcomponents:httpmime:4.3.6'
    compile 'org.apache.httpcomponents:httpcore:4.4.5'
//    compile('org.apache.httpcomponents:httpmime:4.3.6') {
//        exclude module: 'httpclient'
//    }
//
//    compile('org.apache.httpcomponents:httpmime:4.3.6') {
//        exclude module: 'httpclient'
//    }
//    compile 'org.apache.httpcomponents:httpclient-android:4.3.5'

//    compile group: 'org.apache.httpcomponents' , name: 'httpclient-android' , version: '4.3.5.1'
    //compile group: 'org.apache.httpcomponents' , name: 'httpclient-android' , version: '4.3.5.1'
    //compile 'org.apache.httpcomponents:httpclient-android:4.3.5'
    testCompile 'junit:junit:4.12'
}



Буду признателен за любую помощь  !!

Это сообщение отредактировал(а) redradist - 31.7.2017, 22:31
PM MAIL   Вверх
iillyyaa2033
Дата 31.7.2017, 08:44 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 23
Регистрация: 24.6.2017

Репутация: нет
Всего: нет



Для начала, проверьте, что все apache-зависимости свежие и одной версии, а также что это:
Код

compile('org.apache.httpcomponents:httpmime:4.3.5') {
    exclude module: 'httpclient'
}
compile 'org.apache.httpcomponents:httpclient-android:4.3.5'

Выполняется только один раз.

Кстати, в Android есть собственные инструменты для работы c http (до 6.0 использовался apache, после - был удален, но использовать его еще можно).

Кроме того, Вы можете подсмотреть, как устроена работа с jira тут и там.

Пожалуйста, расставьте переносы в коде - страница сломалась.

Это сообщение отредактировал(а) iillyyaa2033 - 1.8.2017, 18:12
PM MAIL   Вверх
redradist
Дата 31.7.2017, 23:06 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 6
Регистрация: 31.7.2017

Репутация: нет
Всего: нет



Спасибо большое за совет iillyyaa2033 но к сожалению первый солющин не помог:

Код

exclude module: 'httpclient'


Я тестируюсь на Android 7 похоже на этой платформе отсутствует необходимая библиотека ...
Буду продолжать поиски солюшина. Если есть еще предложения буду признателен за помощь ...
PM MAIL   Вверх
iillyyaa2033
Дата 1.8.2017, 18:23 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 23
Регистрация: 24.6.2017

Репутация: нет
Всего: нет



1. У Вас версии httpmime и android-client не совпадают.
2. Solution на русский переводится как 'решение'
3. Три следующих подсказки Вы решили пропустить?
PM MAIL   Вверх
redradist
Дата 1.8.2017, 22:40 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 6
Регистрация: 31.7.2017

Репутация: нет
Всего: нет



Просмотрев внимательно предыдущий ответ-замечание я задумался мол может дейсттвительно
где-то подтягивается более новая версия несмотря на то что я прописывал следующее:

Код

compile('org.apache.httpcomponents:httpmime:4.3.5') {
    exclude module: 'httpclient'
}
compile 'org.apache.httpcomponents:httpclient-android:4.3.5'


И действительно просканировав все зависимости я увидел что подтягивалась не та либа а более новая из-за зависимостях в других модулях.
Откатил atlassian либы до следующих:

Код

compile ('com.atlassian.jira:jira-rest-java-client-core:3.0.0')
compile ('com.atlassian.jira:jira-rest-java-client-api:3.0.0')


И вроде бы все заработало ...
Стало падать уже на запросе к серверу Jira-ы:

Код

FATAL EXCEPTION: main
Process: com.smartway.butler.timebutler, PID: 18391
java.lang.IncompatibleClassChangeError: Superclass org.apache.http.params.BasicHttpParams of org.apache.http.params.SyncBasicHttpParams is declared final (declaration of 'org.apache.http.params.SyncBasicHttpParams' appears in /data/app/com.smartway.butler.timebutler-1/split_lib_dependencies_apk.apk:classes5.dex)
                                                                                    at com.atlassian.httpclient.apache.httpcomponents.DefaultHttpClient.<init>(DefaultHttpClient.java:130)
                                                                                    at com.atlassian.jira.rest.client.internal.async.AsynchronousHttpClientFactory.createClient(AsynchronousHttpClientFactory.java:53)
                                                                                    at com.atlassian.jira.rest.client.internal.async.AsynchronousJiraRestClientFactory.create(AsynchronousJiraRestClientFactory.java:35)
                                                                                    at com.atlassian.jira.rest.client.internal.async.AsynchronousJiraRestClientFactory.createWithBasicHttpAuthentication(AsynchronousJiraRestClientFactory.java:42)
                                                                                    at com.smartway.butler.ui.MainActivity.onCreate(MainActivity.java:35)
                                                                                    at android.app.Activity.performCreate(Activity.java:6910)
                                                                                    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1123)
                                                                                    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2746)
                                                                                    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2864)
                                                                                    at android.app.ActivityThread.-wrap12(ActivityThread.java)
                                                                                    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1567)
                                                                                    at android.os.Handler.dispatchMessage(Handler.java:105)
                                                                                    at android.os.Looper.loop(Looper.java:156)
                                                                                    at android.app.ActivityThread.main(ActivityThread.java:6577)
                                                                                    at java.lang.reflect.Method.invoke(Native Method)
                                                                                    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:941)
                                                                                    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:831)


Не подскажешь в чем проблем в этот раз ?
Такое ощущение что я опять заюзал не ту либу или из-за зависимосте подтянулась не та ...
PM MAIL   Вверх
iillyyaa2033
Дата 2.8.2017, 08:22 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 23
Регистрация: 24.6.2017

Репутация: нет
Всего: нет



Вот: зависимости JIRA-Android.

Лично не проверял, но что-то мне подсказывает, что Вам стоит обратить внимание на это:
Код

<dependency>
   <groupId>com.github.kevinsawicki</groupId>
   <artifactId>http-request</artifactId>
   <version>3.0</version>
</dependency>


Это сообщение отредактировал(а) iillyyaa2033 - 2.8.2017, 08:25
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Android | Следующая тема »


 




[ Время генерации скрипта: 0.1210 ]   [ Использовано запросов: 20 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.