android - channel 不可恢复地损坏,将被处理掉

标签 android channel

我正在创建一个客户注册页面,它将客户添加到我的 firebase 数据库中。注册后,应用程序应进入下一个 Activity ,即谷歌地图。客户已添加到数据库中,但在进入下一个 Activity 时崩溃。这是我的代码:

SignupActivityCustomer.java:

import android.content.Intent;
import android.support.annotation.NonNull;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;
import android.util.Patterns;
import android.view.View;
import android.widget.EditText;
import android.widget.ProgressBar;
import android.widget.Toast;

import com.google.android.gms.tasks.OnCompleteListener;
import com.google.android.gms.tasks.Task;
import com.google.firebase.auth.AuthResult;
import com.google.firebase.auth.FirebaseAuth;
import com.google.firebase.database.FirebaseDatabase;

public class SignupActivityCustomer extends AppCompatActivity implements View.OnClickListener {

    private EditText editTextName, editTextEmail, editTextPassword, editTextPhone;
    private ProgressBar progressBar;

    private FirebaseAuth mAuth;

    private static final String TAG = "SignupActivityCustomer";

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_signup_customer);

        editTextName = findViewById(R.id.edit_text_name);
        editTextEmail = findViewById(R.id.edit_text_email);
        editTextPassword = findViewById(R.id.edit_text_password);
        editTextPhone = findViewById(R.id.edit_text_phone);
        progressBar = findViewById(R.id.progressbar);
        progressBar.setVisibility(View.GONE);

        mAuth = FirebaseAuth.getInstance();

        findViewById(R.id.button_register).setOnClickListener(this);
    }

    @Override
    protected void onStart() {
        super.onStart();

        if (mAuth.getCurrentUser() != null) {
            //handle the already login user
        }
    }

    private void registerUser() {
        final String name = editTextName.getText().toString().trim();
        final String email = editTextEmail.getText().toString().trim();
        String password = editTextPassword.getText().toString().trim();
        final String phone = editTextPhone.getText().toString().trim();

        if (name.isEmpty()) {
            editTextName.setError(getString(R.string.input_error_name));
            editTextName.requestFocus();
            return;
        }

        if (email.isEmpty()) {
            editTextEmail.setError(getString(R.string.input_error_email));
            editTextEmail.requestFocus();
            return;
        }

        if (!Patterns.EMAIL_ADDRESS.matcher(email).matches()) {
            editTextEmail.setError(getString(R.string.input_error_email_invalid));
            editTextEmail.requestFocus();
            return;
        }

        if (password.isEmpty()) {
            editTextPassword.setError(getString(R.string.input_error_password));
            editTextPassword.requestFocus();
            return;
        }

        if (password.length() < 6) {
            editTextPassword.setError(getString(R.string.input_error_password_length));
            editTextPassword.requestFocus();
            return;
        }

        if (phone.isEmpty()) {
            editTextPhone.setError(getString(R.string.input_error_phone));
            editTextPhone.requestFocus();
            return;
        }

        if (phone.length() != 10) {
            editTextPhone.setError(getString(R.string.input_error_phone_invalid));
            editTextPhone.requestFocus();
            return;
        }


        progressBar.setVisibility(View.VISIBLE);
        mAuth.createUserWithEmailAndPassword(email, password)
                .addOnCompleteListener(new OnCompleteListener<AuthResult>() {
                    @Override
                    public void onComplete(@NonNull Task<AuthResult> task) {
                        Log.d(TAG, "adding customer");
                        if (task.isSuccessful()) {

                            Customer user = new Customer(
                                    name,
                                    email,
                                    phone
                            );

                            FirebaseDatabase.getInstance().getReference("Customers")
                                    .child(FirebaseAuth.getInstance().getCurrentUser().getUid())
                                    .setValue(user).addOnCompleteListener(new OnCompleteListener<Void>() {
                                @Override
                                public void onComplete(@NonNull Task<Void> task) {
                                    progressBar.setVisibility(View.GONE);
                                    Log.d(TAG, "customer added");
                                    if (task.isSuccessful()) {
                                        startActivity(new Intent(SignupActivityCustomer.this, CustomerHome.class));
                                    } else {
                                        //display a failure message
                                    }
                                }
                            });

                        } else {
                            Toast.makeText(SignupActivityCustomer.this, task.getException().getMessage(), Toast.LENGTH_LONG).show();
                        }
                    }
                });

    }

    @Override
    public void onClick(View v) {
        switch (v.getId()) {
            case R.id.button_register:
                registerUser();
                break;
        }
    }
}

Logcat error:

2019-01-26 11:29:10.843 4038-4038/com.example.julie.fyp D/SignupActivityCustomer: customer added
2019-01-26 11:29:11.669 1880-1959/? W/InputDispatcher: channel '4a251a2 com.example.julie.fyp/com.example.julie.fyp.SignupActivityCustomer (server)' ~ Consumer closed input channel or an error occurred.  events=0x9
2019-01-26 11:29:11.669 1880-1959/? E/InputDispatcher: channel '4a251a2 com.example.julie.fyp/com.example.julie.fyp.SignupActivityCustomer (server)' ~ Channel is unrecoverably broken and will be disposed!
2019-01-26 11:29:11.719 1880-2523/? W/InputDispatcher: Attempted to unregister already unregistered input channel '4a251a2 com.example.julie.fyp/com.example.julie.fyp.SignupActivityCustomer (server)'

最佳答案

据我所知,Firebase 现在是异步工作的,因此它在另一个线程上工作。

你可以尝试将startActivity放在runOnUiThread(Runnable)代码中

if (task.isSuccessful()) {
    runOnUiThread(new Runnable(){
        public void run() {
            startActivity(new Intent(SignupActivityCustomer.this, CustomerHome.class));
        }
    });
} else {
    //display a failure message
}

希望它有用

关于android - channel 不可恢复地损坏,将被处理掉,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54378031/

相关文章:

java - 如何在android中发送短信

java - 如何修复 android 中的布局

android - 使用 'android.intent.action.SEND' 时,接收 Activity 不会返回到启动共享的 Activity

ios - 如何在 Objective - C 中管理两个 FlutterEventChannel

Android org.webrtc.VideoRenderer.I420Frame 数组到 PreviewCallback.onPreviewFrame byte[]

android - 必须引用包含私钥和相应公钥证书链的有效 KeyStore key 条目

go - channel 多路复用器

google-analytics - 在 Google Analytics API 中使用 "default channel grouping"作为维度

tcl - 如何在不使用 TclOO 的情况下插入读取 channel 转换?

goroutine 从具有动态循环的 channel 读取 WaitGroup 在返回之前被重用