質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Firebase

Firebaseは、Googleが提供するBasSサービスの一つ。リアルタイム通知可能、並びにアクセス制御ができるオブジェクトデータベース機能を備えます。さらに認証機能、アプリケーションのログ解析機能などの利用も可能です。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

servlet

Servletとは、Webページの動的な生成やデータ処理などをサーバ上で実行するために、Javaで作成されたプログラムです。 ショッピングサイトやオンラインバンキングといった、動的なウェブサイトの構築に用いられています。

Q&A

0回答

840閲覧

Firebase Admin SDK(Java)を使った、Cloud Messagingを組み込んだServletがエラーを返す

hakase

総合スコア107

Firebase

Firebaseは、Googleが提供するBasSサービスの一つ。リアルタイム通知可能、並びにアクセス制御ができるオブジェクトデータベース機能を備えます。さらに認証機能、アプリケーションのログ解析機能などの利用も可能です。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

servlet

Servletとは、Webページの動的な生成やデータ処理などをサーバ上で実行するために、Javaで作成されたプログラムです。 ショッピングサイトやオンラインバンキングといった、動的なウェブサイトの構築に用いられています。

0グッド

0クリップ

投稿2019/05/03 23:39

編集2019/05/05 00:45

こんにちは。
サーバにtomcatを入れて、Firebase Admin SDK(Java)を使った、Cloud Messagingを組み込んだServletを仕込んで、localhostからPostとしようとしています。

https://firebase.google.com/docs/admin/setup
https://firebase.google.com/docs/cloud-messaging/send-message?hl=ja
を参照して以下のコードを書きましたが、


HTTP Status 500 – Internal Server Error

Type Exception Report

Message Servlet execution threw an exception

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

Exception

javax.servlet.ServletException: Servlet execution threw an exception
org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)

Root Cause

java.lang.NoSuchMethodError: com.google.common.primitives.Booleans.countTrue([Z)I
com.google.firebase.messaging.Message.<init>(Message.java:72)
com.google.firebase.messaging.Message.<init>(Message.java:40)
com.google.firebase.messaging.Message$Builder.build(Message.java:276)
App.doPost(App.java:32)
javax.servlet.http.HttpServlet.service(HttpServlet.java:650)
javax.servlet.http.HttpServlet.service(HttpServlet.java:731)
org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)

Note The full stack trace of the root cause is available in the server logs.
Apache Tomcat/7.0.92


こういうエラーが出ます。
困っています。そもそもコードは合っているんでしょうか?解決のお手伝いをよろしくお願いします。

途中の変数をtoString()をしてみました。参考にして下さい。

GoogleCredentials.fromStream(serviceAccount)の返り値:
ServiceAccountCredentials{clientId=xxx, clientEmail=firebase-adminsdk-y8p0y@xxx.iam.gserviceaccount.com, privateKeyId=xxx, transportFactoryClassName=com.google.auth.oauth2.OAuth2Utils$DefaultHttpTransportFactory, tokenServerUri=https://oauth2.googleapis.com/token, scopes=[], serviceAccountUser=null}

FirebaseOptions options:
com.google.firebase.FirebaseOptions@xxx

Java

1import java.io.*; 2import javax.servlet.*; 3import javax.servlet.http.*; 4import com.google.firebase.*; 5import com.google.firebase.messaging.*; 6import com.google.auth.oauth2.GoogleCredentials; 7 8public class App extends HttpServlet { 9 public void doPost (HttpServletRequest req, HttpServletResponse res) 10 throws ServletException, IOException{ 11 PrintWriter out; 12 13 res.setContentType("text/plain; charset=utf-8"); 14 out = res.getWriter(); 15 16 FileInputStream serviceAccount = new FileInputStream("xxx.json"); 17 18 FirebaseOptions options = new FirebaseOptions.Builder() 19 .setCredentials(GoogleCredentials.fromStream(serviceAccount)) 20 .setDatabaseUrl("https://xxx.firebaseio.com") 21 .build(); 22 23 FirebaseApp.initializeApp(options); 24 25 String deviceToken="xxx"; 26 Message message = Message.builder() 27 .putData("score", "850") 28 .putData("time", "2:45") 29 .setToken(deviceToken) 30 .build(); 31 32 String response=""; 33 try{ 34 response = FirebaseMessaging.getInstance().send(message); 35 } 36 catch(Exception e){ 37 } 38 out.println("Successfully sent message: " + response); 39 } 40}

Gradle

1apply plugin: 'java' 2repositories { 3 mavenCentral() 4 jcenter() 5} 6 7dependencies { 8 // The production code uses the SLF4J logging API at compile time 9 compile 'org.slf4j:slf4j-api:1.7.21' 10 compile 'javax.servlet:javax.servlet-api:3.1.0' 11 compile 'com.google.firebase:firebase-admin:6.8.0' 12 compile 'com.google.apis:google-api-services-oauth2:v1-rev154-1.25.0' 13 testCompile 'junit:junit:4.12' 14}

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問