com.google.firebase.auth.FirebaseAuthException:Firebase ID令牌未由有效公钥签名

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了com.google.firebase.auth.FirebaseAuthException:Firebase ID令牌未由有效公钥签名相关的知识,希望对你有一定的参考价值。

我正在尝试使用firebase admin sdk验证我的java服务器上的android客户端应用程序发送的Id令牌。我跟着

Admin SdkAndroid

FirebaseOptions options = new FirebaseOptions.Builder()
    .setServiceAccount(sce.getServletContext().getResourceAsStream("/WEB-INF/serviceAccountKey.json"))
    .setDatabaseUrl("https://[project-id].firebaseio.com/")
    .build();
FirebaseApp.initializeApp(options);
FirebaseToken decodedToken = FirebaseAuth.getInstance().verifyIdTokenAsync(idToken).get();
    String uid = decodedToken.getUid();

从Android客户端检索ID令牌

mAuth.signInAnonymously()
            .addOnCompleteListener(this, new OnCompleteListener<AuthResult>() {
   @Override
   public void onComplete(@NonNull Task<AuthResult> task) {
       if (task.isSuccessful()) {
           final FirebaseUser user = mAuth.getCurrentUser();
           user.getIdToken(true).addOnCompleteListener(new OnCompleteListener<GetTokenResult>() {
               @Override
               public void onComplete(@NonNull Task<GetTokenResult> task) {
                   String token = task.getResult().getToken();
                   Log.e(TAG,"signInAnonymously:success :  onComplete : "+token);
                   callApi(token);
               }
           });

        } else {
            // If sign in fails, display a message to the user.
            Toast.makeText(SignIn.this, "Authentication failed.",
            Toast.LENGTH_SHORT).show();
        }

    }
});

在服务器上获取异常

com.google.firebase.auth.FirebaseAuthException:Firebase ID令牌未由有效公钥签名。有关如何检索ID令牌的详细信息,请参阅https://firebase.google.com/docs/auth/admin/verify-id-tokens。 com.google.firebase.auth.internal.FirebaseTokenVerifier.verifyTokenAndSignature(FirebaseTokenVerifier.java:147)位于com.google.fire.Auth $ .call(FirebaseAuth.java:223)com.google.firebase.auth的com.google.firebase.auth.FirebaseAuth $ .call。位于java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)的com.google.firebase.tasks.Tasks $ 1.run(Tasks.java:82)上的FirebaseAuth $ 2.call(FirebaseAuth.java:211) java.lang.Thread.run中的.util.concurrent.ThreadPoolExecutor $ Worker.run(ThreadPoolExecutor.java:624)(Thread.java:748)

答案

你可以试试这段代码。(如果不使用,只删除setDatabaseUrl。)

FirebaseOptions options = new FirebaseOptions.Builder()
.setServiceAccount(sce.getServletContext().getResourceAsStream("/WEB-INF/serviceAccountKey.json"))
.build();

以上是关于com.google.firebase.auth.FirebaseAuthException:Firebase ID令牌未由有效公钥签名的主要内容,如果未能解决你的问题,请参考以下文章

修复了警告活动#com.google.firebase.auth.internal.FederatedSignInActivity@android:launchMode的标签为AndroidManif

使用自己的身份验证服务器的firebase-auth模块和firebase-common-auth的重复

Flutter error:尝试在空对象引用上调用虚方法'void com.google.firebase.auth.internal.zzab.zzf(int)',null(示例代码

FirebaseAuth.getInstance()为null

Firebase Android 身份验证失败:expired_token(身份验证令牌已过期)

如果通知在脱机时发送,Android是否可以检索FCM通知