让我更清楚地说明这一点。我已经在Tomcat 8,firebase-admin库版本5.2.0,JSF 2.2,jersey-json 1.18.1和Jersey 1.14中使用Java 8设置了我的项目。 服务器启动时,我收到一些错误,如下所示:
jul 11, 2017 5:23:47 PM org.apache.catalina.core.StandardContext loadOnStartup
GRAVE: Servlet [Jersey Web Application] in web application [/core-web-app] threw load() exception
java.lang.ArrayIndexOutOfBoundsException: 2560
at org.objectweb.asm.ClassReader.accept(Unknown Source)
at org.objectweb.asm.ClassReader.accept(Unknown Source)
at com.sun.jersey.spi.scanning.AnnotationScannerListener.onProcess(AnnotationScannerListener.java:136)
at com.sun.jersey.spi.scanning.servlet.WebAppResourcesScanner$2.f(WebAppResourcesScanner.java:104)
at com.sun.jersey.core.util.Closing.f(Closing.java:71)
I realized that this error takes places when i Have the folowing code in my class:
Task<UserRecord> task = FirebaseAuth.getInstance().createUser(request)
.addOnSuccessListener(userRecord -> {
System.out.println("Successfully created new user: " + userRecord.getUid());
try {
createLocalAccount(account, userRecord.getUid());
} catch (Exception exception) {
exception.printStackTrace();
}
})
.addOnFailureListener(e -> {
System.err.println("Error creating new user: " + e.getMessage());
});
如果删除上述代码,则在服务器启动时不会显示任何错误。 泽西岛和火碱管理库之间是否存在冲突?我该如何解决这个问题?
这不太可能是由 Firebase 和 Jersey 库之间的某些不兼容引起的。至少我不知道有这样的问题。泽西岛似乎直到1.19版本才添加Java 8支持。因此,您可能需要升级您的泽西岛版本(v1.14 大约有 5 年的历史(。您也可以尝试摆脱lambda和任何其他Java 8语法,但它可能无法完全解决问题。
开发人员也有类似的报告,他们在使用 Java 8 代码(特别是 lambda(与旧版本的 Jersey 一起工作时遇到了问题。例如:REST 服务中的 Java 8 Lambda 表达式不起作用