Класс Java обычно компилируется самостоятельно, но выдает NoClassFoundException или NoClassDefFoundError при запуске через JSP - PullRequest
0 голосов
/ 30 мая 2018

У меня есть класс Java, который успешно отправляет сообщение Firebase на мой телефон Android.Я пытаюсь запустить этот класс из файла JSP, но это приводит к NoClassFoundException и NoClassDefFoundError.Вот файл JSP:

<%@ page import="send.Notify" %>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>Title</title>
</head>
<body>
    Api token is: <%
        out.print(request.getParameter("token"));
    %>
<%

Notify.SendMessage(request.getParameter("token"),"title","body");
%>
</body>
</html>

Для ясности, я получаю нормальный вывод из out.print, когда Notify.SendMessage закомментирован, поэтому проблема не в вводе.

Вот мой класс:

package send;

import com.google.api.client.googleapis.auth.oauth2.GoogleCredential;
import com.google.auth.oauth2.GoogleCredentials;
import com.google.firebase.FirebaseApp;
import com.google.firebase.FirebaseOptions;
import com.google.firebase.messaging.FirebaseMessaging;
import com.google.firebase.messaging.Message;
import com.google.firebase.messaging.Notification
import java.io.FileInputStream;
import java.io.IOException;
import java.util.Arrays;

public class Notify {
public static void main(String[] args) throws Exception{

    SendMessage("f7ne...",
            "title", "body");
}

public static void SendMessage(String registrationToken, String title, String body) throws Exception{
    FileInputStream serviceAccount =
            new FileInputStream("C:\\Users\\michael\\IdeaProjects\\servlet 3\\web\\notification-32ebc-firebase-adminsdk-5lbs4-643271e91a.json");

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

    FirebaseApp.initializeApp(options);

    Notification notification = new Notification(title, body);
    Message message = Message.builder()
            .setToken(registrationToken)
            .setNotification(notification)
            .build();


    String response = FirebaseMessaging.getInstance().send(message);
    System.out.println(response);
}
private static String getAccessToken() throws IOException {
    GoogleCredential googleCredential = GoogleCredential
            .fromStream(new FileInputStream("C:\\Users\\michael\\IdeaProjects\\servlet 3\\web\\notification-32ebc-firebase-adminsdk-5lbs4-643271e91a.json"))
            .createScoped(Arrays.asList("https://www.googleapis.com/auth/firebase.messaging",
                    "https://www.googleapis.com/auth/firebase.database",
                    "https://www.googleapis.com/auth/userinfo.email",
                    "https://www.googleapis.com/auth/firebase"));
    googleCredential.refreshToken();
    return googleCredential.getAccessToken();
}

}

Вот ошибка:

Type Exception Report

Message An exception occurred processing [/notification.jsp] at line [15]

Description The server encountered an unexpected condition that prevented it from fulfilling the request.

Exception

org.apache.jasper.JasperException: An exception occurred processing [/notification.jsp] at line [15]

12:         /*Notify.SendMessage("f7neXi6q4KQ:APA91bFI3acBwgtDq99_D2duax_qY1zAMGCE62yHQ5CsL-UhyJdvAs97CUhzXzY0q7tyWKX2JM0WlyvZtL-arTW9s1useO816ujda5c4gYKM-I_uCN8m81EH9clwNeVG6kQzGU-zl93k",
13:                 "jsp title", "jsp body");*/
14:         try{
15:             Notify.SendMessage(request.getParameter("token"),"title","body");
16:         }catch (Exception e){
17:             out.print("error!");
18:         }


Stacktrace:
    org.apache.jasper.servlet.JspServletWrapper.handleJspException(JspServletWrapper.java:593)
    org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:467)
    org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:386)
    org.apache.jasper.servlet.JspServlet.service(JspServlet.java:330)
    javax.servlet.http.HttpServlet.service(HttpServlet.java:741)
    org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53)
Root Cause

javax.servlet.ServletException: java.lang.NoClassDefFoundError: com/google/firebase/FirebaseOptions$Builder
    org.apache.jasper.runtime.PageContextImpl.handlePageException(PageContextImpl.java:667)
    org.apache.jsp.notification_jsp._jspService(notification_jsp.java:154)
    org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:70)
    javax.servlet.http.HttpServlet.service(HttpServlet.java:741)
    org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:444)
    org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:386)
    org.apache.jasper.servlet.JspServlet.service(JspServlet.java:330)
    javax.servlet.http.HttpServlet.service(HttpServlet.java:741)
    org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53)
Root Cause

java.lang.NoClassDefFoundError: com/google/firebase/FirebaseOptions$Builder
    send.Notify.SendMessage(Notify.java:26)
    org.apache.jsp.notification_jsp._jspService(notification_jsp.java:135)
    org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:70)
    javax.servlet.http.HttpServlet.service(HttpServlet.java:741)
    org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:444)
    org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:386)
    org.apache.jasper.servlet.JspServlet.service(JspServlet.java:330)
    javax.servlet.http.HttpServlet.service(HttpServlet.java:741)
    org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53)
Root Cause

java.lang.ClassNotFoundException: com.google.firebase.FirebaseOptions$Builder
    org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1292)
    org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1121)
    send.Notify.SendMessage(Notify.java:26)
    org.apache.jsp.notification_jsp._jspService(notification_jsp.java:135)
    org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:70)
    javax.servlet.http.HttpServlet.service(HttpServlet.java:741)
    org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:444)
    org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:386)
    org.apache.jasper.servlet.JspServlet.service(JspServlet.java:330)
    javax.servlet.http.HttpServlet.service(HttpServlet.java:741)
    org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53)
Note The full stack trace of the root cause is available in the server logs.

Вот моя структура папок: https://prnt.sc/jocl6h

Ответы [ 2 ]

0 голосов
/ 31 мая 2018

Баночка firebase-core отсутствует в пути к классам.Документация FireBase содержит инструкции для Gradle.

dependencies { implementation 'com.google.firebase:firebase-core:16.0.1' }

Если вы используете maven, замените зависимость соответствующей декларацией maven

<dependency> <groupId>com.google.firebase</groupId> <artifactId>firebase-core</artifactId> <version>16.0.1</version> </dependency>

0 голосов
/ 31 мая 2018

Проблема заключалась в том, что Intellij не использует зависимости, которые вы добавили в проект также на сервер Tomcat.Чтобы это исправить, я вручную добавил все файлы jar из папки maven (C: \ Users \ user.m2) в папку project / web / WEB-INF / lib.

Это решение, но яЯ все еще ищу правильный способ сделать это.

Обновление: я недавно пытался реорганизовать свою программу.В IntelliJ создайте новый проект maven из архетипа веб-приложения apache.Затем вы можете добавить все свои зависимости и классы, и Tomcat успешно найдет их все.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...