При вызове API Android mongodb.stitch не удается получить RemoteMongoClient

#android #mongodb

#Android #mongodb

Вопрос:

Я выполнил шаги по отправке данных в Mongo db с помощью приложения Android.

Ссылка:

https://code.tutsplus.com/tutorials/how-to-use-mongodb-stitch-in-android-apps—cms-31877

Но коду не удается получить объект удаленного клиента.

Вот фрагмент кода, который завершается с ошибкой:

 private void logIN(){
        final StitchAppClient mongoClient1 = Stitch.getDefaultAppClient();
        mongoClient1.getAuth().loginWithCredential(new AnonymousCredential()).addOnSuccessListener(new OnSuccessListener<StitchUser>() {
            @Override
            public void onSuccess(StitchUser stitchUser) {
                Log.v(TAG,"success");
                try {
                    RemoteMongoClient remoteMongoClient =
                            client.getServiceClient(RemoteMongoClient.factory, "mongodb-atlas");

                    // Set up the atlas collection
                    RemoteMongoCollection<Document> coll = remoteMongoClient
                            .getDatabase(DATABASE_NAME).getCollection(COLLECTION_NAME);
                }catch (Exception e){
                    e.getMessage();
                }
               // post();
            }
        });
    }
 

Этот метод завершается с ошибкой при вызове API getServiceClient.

Вот ошибка logcat:

 04-17 15:36:39.478 22667-23111/com.ecom.analyticsmongo E/AndroidRuntime: FATAL EXCEPTION: Thread-5
    Process: com.ecom.analyticsmongo, PID: 22667
    java.lang.BootstrapMethodError: Exception from call site #0 bootstrap method
        at com.mongodb.stitch.android.services.mongodb.remote.RemoteMongoClient.<clinit>(RemoteMongoClient.java:37)
        at com.ecom.analyticsmongo.MainActivity$2$1.run(MainActivity.java:61)
        at java.lang.Thread.run(Thread.java:764)
     Caused by: java.lang.ClassCastException: Bootstrap method returned null
        at com.mongodb.stitch.android.services.mongodb.remote.RemoteMongoClient.<clinit>(RemoteMongoClient.java:37) 
        at com.ecom.analyticsmongo.MainActivity$2$1.run(MainActivity.java:61) 
        at java.lang.Thread.run(Thread.java:764

Позвольте мне, что может быть причиной этого сбоя. Или если кто-нибудь сталкивался с такой ошибкой во время выполнения

Ответ №1:

Проблема заключалась в настройке gradle для версии JAVA. Нам нужно определить это в градации проектов:

 compileOptions {
        sourceCompatibility = JavaVersion.VERSION_1_8
        targetCompatibility = JavaVersion.VERSION_1_8
    }
 

После определения этого я мог видеть, что код теперь работает нормально.

Спасибо