1

Google App Engine에서 Firebase 데이터베이스를 조작하려고합니다. 아래에있는 내 코드와 같이클래스를 초기화 할 수 없습니다. Firebase에서 FirebaseThreadManagers 오류가 발생했습니다.

org.slf4j.LoggerFactory is a restricted class. Please see the Google App Engine developer's guide for more details. 

오류는 FirebaseOptions에서 발생

java.lang.NoClassDefFoundError: Could not initialize class com.google.firebase.internal.FirebaseThreadManagers

때때로 나는 다음을 참조 - 다음 자습서를 가지고, 나는 다음과 같은 오류를 받고 있어요. 여기

 FileInputStream serviceAccount = new FileInputStream("WEB-INF/MyApp.json"); 

    FirebaseOptions options = new FirebaseOptions.Builder() 
      .setCredentials(GoogleCredentials.fromStream(serviceAccount)) 
      .setDatabaseUrl("https://MyApp.firebaseio.com") 
      .build(); 

    FirebaseApp.initializeApp(options); 

다음은 백엔드 내 build.gradle의 전체

java.lang.NoClassDefFoundError: Could not initialize class com.google.firebase.internal.FirebaseThreadManagers at com.google.firebase.FirebaseOptions$Builder.(FirebaseOptions.java:147) at com.example.name.myapplication.backend.MyServlet.doGet(MyServlet.java:55) at javax.servlet.http.HttpServlet.service(HttpServlet.java:617) at javax.servlet.http.HttpServlet.service(HttpServlet.java:717) at org.mortbay.jetty.servlet.ServletHolder.handle(ServletHolder.java:511) at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1166) at com.google.appengine.api.blobstore.dev.ServeBlobFilter.doFilter(ServeBlobFilter.java:63) at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1157) at com.google.appengine.tools.development.DevAppServerModulesFilter.doRedirectedModuleRequest(DevAppServerModulesFilter.java:415) at com.google.appengine.tools.development.DevAppServerModulesFilter.doFilter(DevAppServerModulesFilter.java:128) at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1157) at org.mortbay.jetty.servlet.ServletHandler.handle(ServletHandler.java:388) at org.mortbay.jetty.security.SecurityHandler.handle(SecurityHandler.java:216) at org.mortbay.jetty.servlet.SessionHandler.handle(SessionHandler.java:182) at org.mortbay.jetty.handler.ContextHandler.handle(ContextHandler.java:765) at org.mortbay.jetty.webapp.WebAppContext.handle(WebAppContext.java:418) at com.google.appengine.tools.development.DevAppEngineWebAppContext.handle(DevAppEngineWebAppContext.java:98) at org.mortbay.jetty.servlet.Dispatcher.forward(Dispatcher.java:327) at org.mortbay.jetty.servlet.Dispatcher.forward(Dispatcher.java:126) at com.google.appengine.tools.development.JettyContainerService.forwardToServer(JettyContainerService.java:458) at com.google.appengine.tools.development.Modules.forwardToInstance(Modules.java:372) at com.google.appengine.tools.development.DelegatingModulesFilterHelper.forwardToInstance(DelegatingModulesFilterHelper.java:95) at com.google.appengine.tools.development.DevAppServerModulesFilter.doRedirect(DevAppServerModulesFilter.java:326) at com.google.appengine.tools.development.DevAppServerModulesFilter.doFilter(DevAppServerModulesFilter.java:119) at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1157) at org.mortbay.jetty.servlet.ServletHandler.handle(ServletHandler.java:388) at org.mortbay.jetty.security.SecurityHandler.handle(SecurityHandler.java:216) at org.mortbay.jetty.servlet.SessionHandler.handle(SessionHandler.java:182) at org.mortbay.jetty.handler.ContextHandler.handle(ContextHandler.java:765) at org.mortbay.jetty.webapp.WebAppContext.handle(WebAppContext.java:418) at com.google.appengine.tools.development.DevAppEngineWebAppContext.handle(DevAppEngineWebAppContext.java:98) at org.mortbay.jetty.handler.HandlerWrapper.handle(HandlerWrapper.java:152) at com.google.appengine.tools.development.JettyContainerService$ApiProxyHandler.handle(JettyContainerService.java:511) at org.mortbay.jetty.handler.HandlerWrapper.handle(HandlerWrapper.java:152) at org.mortbay.jetty.Server.handle(Server.java:326) at org.mortbay.jetty.HttpConnection.handleRequest(HttpConnection.java:542) at org.mortbay.jetty.HttpConnection$RequestHandler.headerComplete(HttpConnection.java:923) at org.mortbay.jetty.HttpParser.parseNext(HttpParser.java:547) at org.mortbay.jetty.HttpParser.parseAvailable(HttpParser.java:212) at org.mortbay.jetty.HttpConnection.handle(HttpConnection.java:404) at org.mortbay.io.nio.SelectChannelEndPoint.run(SelectChannelEndPoint.java:409) at org.mortbay.thread.QueuedThreadPool$PoolThread.run(QueuedThreadPool.java:582)

의 오류입니다

buildscript { 
    repositories { 
     jcenter() 
    } 
    dependencies { 
     classpath 'com.google.appengine:gradle-appengine-plugin:1.9.42' 
    } 
} 

repositories { 
    jcenter(); 
} 

apply plugin: 'java' 
apply plugin: 'war' 
apply plugin: 'appengine' 

sourceCompatibility = JavaVersion.VERSION_1_7 
targetCompatibility = JavaVersion.VERSION_1_7 

dependencies { 
    appengineSdk 'com.google.appengine:appengine-java-sdk:1.9.42' 
    compile 'javax.servlet:servlet-api:2.5' 
    compile 'com.google.firebase:firebase-admin:5.5.0' 
    compile 'com.squareup.retrofit2:retrofit:2.1.0' 
    compile 'com.squareup.retrofit2:converter-gson:2.1.0' 
    compile 'com.google.code.gson:gson:2.6.1' 


    appengine { 
     downloadSdk = true 
     appcfg { 
      oauth2 = true 
     } 
    } 
} 

최고 수준의 빌드 파일 :

buildscript { 
    repositories { 
     jcenter() 
    } 
    dependencies { 
     classpath 'com.android.tools.build:gradle:3.0.1' 


     // NOTE: Do not place your application dependencies here; they belong 
     // in the individual module build.gradle files 
     classpath 'com.google.gms:google-services:3.1.0' 
    } 
} 

allprojects { 
    repositories { 
     jcenter() 
     maven { url "https://maven.google.com" } 
    } 
} 

task clean(type: Delete) { 
    delete rootProject.buildDir 
} 
+0

"android"및 "google-app-engine"으로 태그를 지정했습니다. 그것은 하나 또는 다른 것이 어야만하는 것처럼 보이지만 둘 다 아닌 것처럼 보입니다. GAE에서 firebase-admin SDK를 사용하고 있습니까? –

+0

죄송합니다, 예. Android 앱의 백엔드로 Google App Engine을 사용하고 있습니다. 이것은 단지 GAE와 관련이 있습니다. Firebase-admin SDK를 사용 중입니다. 그것은 firebase-database와 firebase-core와 함께 나의 의존성 중 하나입니다. – PSLDev

+0

정확한'build.gradle'을 테스트 한 결과 제대로 작동했습니다. 내 직감은 프로젝트에서 안드로이드 플러그인을 사용하면 일관성없는 상태로 남아 있다는 것입니다. 나는 프로젝트 디렉토리 ('gradle clean')를 청소하고 응용 프로그램을 다시 실행하도록 권장합니다. –

답변

0

는 사용하지 마십시오 firebase-admin 의존성과 다른 Android cl 서버 응용 프로그램의 ient 라이브러리. firebase-admin 만 있으면 JVM 런타임에서 실시간 데이터베이스에 액세스하는 데 필요한 모든 것이 있습니다. Android 클라이언트 라이브러리는 Android 인프라가 필요하기 때문에 서버 앱에서는 사용할 수 없습니다.

+0

다른 Firebase 종속성을 제거하면 "오류 : 버전 : 5.5.0이 Google 서비스 플러그인에 필요한 최소 버전 (9.0.0)보다 낮습니다. ". 최상위 레벨 빌드 파일에서 저장소 아래에 "classpath 'com.google.gms : google-services : 3.1.0'"및 "maven {url"https://maven.google.com "}"이 있습니다. – PSLDev

+0

또한 Android가 아닌 gradle 빌드에 google-services 플러그인을 사용하지 마십시오. –

+0

나는 그 변화를 만들었지 만 여전히 불행하게도 같은 오류를주고있다. – PSLDev