Невозможно создать PhoneAuthCredential без проверкиProof, sessionInfo или временного доказательства.пока я удаляю firebase пользователя - PullRequest
1 голос
/ 03 мая 2019

Я использую Firebase и Android Studio. и у меня возникла проблема при попытке удалить пользователя. Единственный способ получить доступ к Моему приложению - это аутентификация по номеру телефона.

Я уже знаю об этом, когда я удаляю пользователя, должна пройти повторную аутентификацию. Поэтому я сослался на документацию Firebase и попробовал их. Метод AuthCredential.getCredential () требует нескольких значений, хотя у меня есть только PhoneNumber и UID. это все, что я знаю

Это код

AuthCredential credential = PhoneAuthProvider
                        .getCredential(user.getUid(), null);

                user.reauthenticate(credential)
                .addOnCompleteListener(new OnCompleteListener<Void>() {

                    //재인증 성공시
                    @Override
                    public void onComplete(@NonNull Task<Void> task) {

                        //삭제
                        user.delete()
                        .addOnCompleteListener(new OnCompleteListener<Void>() {
                            @Override
                            public void onComplete(@NonNull Task<Void> task) {
                                if (task.isSuccessful()) {
                                    Log.d("result", "User account deleted.");
                                }else{
                                    Log.d("", task.getException().getStackTrace().toString());
                                }
                            }
                        });
                    }
                });

И это исключения :

java.lang.IllegalArgumentException: Cannot create PhoneAuthCredential without either verificationProof, sessionInfo, ortemprary proof.
        at com.google.android.gms.common.internal.Preconditions.checkArgument(Unknown Source)
        at com.google.firebase.auth.PhoneAuthCredential.<init>(Unknown Source)
        at com.google.firebase.auth.PhoneAuthProvider.getCredential(Unknown Source)
        at com.dataflow.deliverytalk.Activities.popup.LogoutPopupActivity$1$override.onClick(LogoutPopupActivity.java:58)
        at com.dataflow.deliverytalk.Activities.popup.LogoutPopupActivity$1$override.access$dispatch(LogoutPopupActivity.java)
        at com.dataflow.deliverytalk.Activities.popup.LogoutPopupActivity$1.onClick(LogoutPopupActivity.java)
        at android.view.View.performClick(View.java:5637)
        at android.view.View$PerformClick.run(View.java:22429)
        at android.os.Handler.handleCallback(Handler.java:751)
        at android.os.Handler.dispatchMessage(Handler.java:95)
        at android.os.Looper.loop(Looper.java:154)
        at android.app.ActivityThread.main(ActivityThread.java:6119)
        at java.lang.reflect.Method.invoke(Native Method)
        at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:886)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:776)

1 Ответ

1 голос
/ 03 мая 2019

Очевидно, что вы также можете удалить пользователя, используя облачную функцию, без необходимости повторной аутентификации пользователя и просто предоставив идентификатор пользователя. Вот как

exports.deleteUser = functions.https.onRequest((req, res) => {
  if (req.body.uid === undefined) {
    res.status(400).send('No user id defined');
  } else {
    var userId = req.body.uid;

    admin.auth().deleteUser(userId)
        .then(function() {
            console.log("Successfully deleted user");    
        })
        .catch(function(error) {
            console.log("Error deleting user: ", error);
        });

    res.status(200).end();
}
});

Подробнее Информация

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