我是Android dev和Firebase的新手。
我需要以下帮助:
用户使用Firebase密码身份验证进行身份验证(片段称为SignUp)后,将其保存为实时数据库中的用户 - > UID->个人电子邮件。然后,他们转移到新的片段 - AddUsername片段。此片段要求提供唯一的用户名。
我想要实现的是,如果用户在未输入用户名的情况下退出并关闭应用程序,则会从Firebase控制台中删除实时数据库中保存的数据,并将用户带回“注册”片段以重新启动注册过程。这可以防止创建错误地退出"退出的非活动电子邮件帐户或帐户。并且电子邮件地址无法重复使用。
到目前为止,这是我的代码,我不知道我需要用什么代码才能完成此任务。
编辑:我已经在AddUsername片段的onDestroyView()上添加了此代码。当我按下“返回”按钮时,实时数据库中的数据将被删除,但当我关闭应用程序时,数据不会被删除。
@Override
public void onDestroyView() {
super.onDestroyView();
mAuth.signOut();
mDatabase.child("users").child(user.getUid()).removeValue();
Log.i("User: ", "Not saved in database");
user.delete()
.addOnCompleteListener(new OnCompleteListener<Void>() {
@Override
public void onComplete(@NonNull Task<Void> task) {
if (task.isSuccessful()) {
Log.d(TAG, "User account deleted.");
}
}
});
}
提前谢谢。
public class AddUsername extends Fragment实现了View.OnClickListener,TextWatcher {
public AddUsername() {
}
public interface FragmentComm {
void toSetName();
}
private TextView title, headings, handleError;
private EditText addUsername;
private Button nextButton;
private String getUsername;
private FirebaseAuth mAuth;
private FirebaseUser user;
private DatabaseReference mDatabase;
private FragmentComm fragmentComm;
@Override
public void onAttach(Context context) {
super.onAttach(context);
fragmentComm = (FragmentComm) getActivity();
user = FirebaseAuth.getInstance().getCurrentUser();
mAuth = FirebaseAuth.getInstance();
mDatabase = FirebaseDatabase.getInstance().getReference();
}
@Nullable
@Override
public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
View view = inflater.inflate(R.layout.add_username, container, false);
title = view.findViewById(R.id.username_title);
headings = view.findViewById(R.id.display_user_message);
handleError = view.findViewById(R.id.message_error);
addUsername = view.findViewById(R.id.addUsername);
nextButton = view.findViewById(R.id.nextButton);
nextButton.setOnClickListener(this);
addUsername.addTextChangedListener(this);
return view;
}
@Override
public void beforeTextChanged(CharSequence s, int start, int count, int after) {
}
@Override
public void onTextChanged(CharSequence s, int start, int before, int count) {
}
@Override
public void afterTextChanged(Editable s) {
getUsername = addUsername.getText().toString();
if (getUsername.isEmpty()) {
handleError.setVisibility(View.GONE);
nextButton.setBackgroundColor(Color.parseColor("#EEEEEE"));
nextButton.setTextColor(Color.parseColor("#BDBDBD"));
nextButton.setEnabled(false);
} else {
Query query = FirebaseDatabase.getInstance().getReference().child("users").orderByChild("username").equalTo(getUsername);
query.addListenerForSingleValueEvent(new ValueEventListener() {
@Override
public void onDataChange(DataSnapshot dataSnapshot) {
if (dataSnapshot.exists()) {
handleError.setText(R.string.username_not_available);
handleError.setVisibility(View.VISIBLE);
handleError.setTextColor(Color.parseColor("#F50057"));
nextButton.setBackgroundColor(Color.parseColor("#EEEEEE"));
nextButton.setTextColor(Color.parseColor("#BDBDBD"));
nextButton.setEnabled(false);
} else {
handleError.setText(R.string.username_available);
handleError.setVisibility(View.VISIBLE);
handleError.setTextColor(Color.parseColor("#26C485"));
nextButton.setBackgroundColor(Color.parseColor("#0277BD"));
nextButton.setTextColor(Color.parseColor("#FFFFFF"));
nextButton.setEnabled(true);
}
}
@Override
public void onCancelled(DatabaseError databaseError) {
Log.i("Give info", "Error");
}
});
}
}
@Override
public void onClick(View v) {
switch (v.getId()) {
case R.id.nextButton:
checkUsernameAlreadyExist();
}
}
private void checkUsernameAlreadyExist() {
getUsername = addUsername.getText().toString();
Query query = FirebaseDatabase.getInstance().getReference().child("users").orderByChild("username").equalTo(getUsername);
query.addListenerForSingleValueEvent(new ValueEventListener() {
@Override
public void onDataChange(DataSnapshot dataSnapshot) {
if (dataSnapshot.exists()) {
handleError.setText(R.string.username_not_available);
handleError.setVisibility(View.VISIBLE);
handleError.setTextColor(Color.parseColor("#F50057"));
} else {
handleError.setText(R.string.username_available);
handleError.setVisibility(View.VISIBLE);
handleError.setTextColor(Color.parseColor("#26C485"));
fragmentComm.toSetName();
setDatabaseName();
}
}
@Override
public void onCancelled(DatabaseError databaseError) {
Log.i("Give info", "Error");
}
});
}
private void setDatabaseName() {
mDatabase.child("users").child(user.getUid()).child("username").setValue(getUsername);
}
答案 0 :(得分:2)
我认为这可能是onDisconnect
处理程序的一个很好的用例。这些是应用程序在连接时发送到Firebase数据库的写入指令,一旦检测到客户端消失,数据库服务器就会执行。
这方面的一个例子:
private void setDatabaseName() {
DatabaseReference usernameRef = mDatabase.child("users").child(user.getUid()).child("username");
usernameRef.setValue(getUsername);
usernameRef.onDisconnection().removeValue();
}
有关详情,请参阅Firebase documentation on onDisconnect
handlers。
这只适用于数据库。您可能必须找到另一种方法来清理Firebase身份验证帐户。
另请注意,您为确保唯一用户名而采取的方法效率不高。有关更惯用的方法,请参阅:
答案 1 :(得分:0)
我认为你需要添加用于删除它的相同代码,包含if条件,检查用户是否输入了用户名,在活动本身的onDestroy()
和onPause()
中
但请注意,如果应用程序为onDestroy()
,则可以绕过onStop()
和onPause()
方法将其关闭,因此您可能需要在{{1}中添加代码同样,但在恢复后,用户将需要从头开始