Java Android-Firebase-不同类型的用户登录

Java Android-Firebase-不同类型的用户登录,java,android,firebase,firebase-realtime-database,firebase-authentication,Java,Android,Firebase,Firebase Realtime Database,Firebase Authentication,目标 允许不同类型的用户登录到各自的界面 说明 用户类型(3): 学生 母公司 老师 每个用户都通过Firebase身份验证电子邮件进行注册 每个用户都应该能够访问各自的界面,因为每个界面都不同于其他界面 每个用户已与其各自的子节点一起保存在Firebase数据库中。例如,在“用户”下面有一个“学校”,下面是用户类型,如“学生”、“家长”和“老师” 用于可视化目的的数据库 使用者 ->学校 ------>学生 ------>母公司 ------>老师 问题 由于我目前正在使用Fire

目标

允许不同类型的用户登录到各自的界面

说明

  • 用户类型(3):

  • 学生
  • 母公司
  • 老师
  • 每个用户都通过Firebase身份验证电子邮件进行注册

  • 每个用户都应该能够访问各自的界面,因为每个界面都不同于其他界面

  • 每个用户已与其各自的子节点一起保存在Firebase数据库中。例如,在“用户”下面有一个“学校”,下面是用户类型,如“学生”、“家长”和“老师”

用于可视化目的的数据库

  • 使用者
->学校

------>学生

------>母公司

------>老师

问题

由于我目前正在使用Firebase身份验证电子邮件,我无法区分哪个用户是哪个用户

建议的解决方案是创建一个包含3种用户类型的单选按钮,供用户在登录应用程序时选择。这意味着用户必须通过输入电子邮件、密码和选择用户类型来登录

问题是,如果“学生”用户在单选按钮上选择“家长”或“老师”并使用学生电子邮件登录,应用程序仍会将“学生”电子邮件识别为“家长”或“老师”怎么办

后勤活动类

import android.content.Intent;
import android.support.annotation.NonNull;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.support.v7.widget.Toolbar;
import android.text.TextUtils;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
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.auth.FirebaseAuthException;

public class LoginActivity extends AppCompatActivity {

    private Toolbar jLoginToolbar;

    private EditText jLoginEmail;
    private EditText jLoginPassword;

    private Button jLoginBtn;
    private Button jAdminLoginBtn;
    private FirebaseAuth mAuth;

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

        mAuth = FirebaseAuth.getInstance();

        jLoginToolbar = (Toolbar) findViewById(R.id.loginToolbar);
        setSupportActionBar(jLoginToolbar);
        getSupportActionBar().setTitle("Account Login");
        getSupportActionBar().setDisplayHomeAsUpEnabled(true);

        jLoginEmail = (EditText) findViewById(R.id.loginEmail);
        jLoginPassword = (EditText) findViewById(R.id.loginPassword);
        jLoginBtn = (Button) findViewById(R.id.loginBtn);
        jAdminLoginBtn = (Button) findViewById(R.id.loginAdminBtn);

        jAdminLoginBtn.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                    Intent intentAdmin = new Intent(LoginActivity.this, AdminLoginActivity.class);
                    startActivity(intentAdmin);
            }
        });

        jLoginBtn.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                String userLoginEmail = jLoginEmail.getText().toString();
                String userLoginPassword = jLoginPassword.getText().toString();

                if(!TextUtils.isEmpty(userLoginEmail)&& !TextUtils.isEmpty(userLoginPassword)) {
                    loginUser(userLoginEmail, userLoginPassword);
                }else{
                    Toast.makeText(LoginActivity.this, "Failed Login: Empty Inputs are not allowed", Toast.LENGTH_SHORT).show();
                }
            }
        });

    }

    private void loginUser(final String userLoginEmail, final String userLoginPassword) {
        mAuth.signInWithEmailAndPassword(userLoginEmail, userLoginPassword)
                .addOnCompleteListener(this, new OnCompleteListener<AuthResult>() {
                    @Override
                    public void onComplete(@NonNull Task<AuthResult> task) {
                        if (task.isSuccessful()) {
                            Intent intentMain = new Intent(LoginActivity.this, MainActivity.class);
                            intentMain.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK | Intent.FLAG_ACTIVITY_CLEAR_TASK);
                            startActivity(intentMain);
                            finish();
                        }else{
                            FirebaseAuthException e = (FirebaseAuthException )task.getException();
                            Toast.makeText(LoginActivity.this, "Failed Login: "+e.getMessage(), Toast.LENGTH_SHORT).show();
                            return;
                        }
                    }
                });
    }
}
UserCode将是一个EditText,允许用户输入“UserCode”,即使这个想法的概念与单选按钮的概念类似,但它将提供更多的安全性,因为“UserCode”充当“次要”密码,用户只能从我(管理员)那里知道它。告诉我你的想法



>>>>>>>>>>>>>>>>>>>>>>>>>>>>解决方案您只需在用户首次注册应用程序时验证其是否为家长、学生或教师。之后,在Firebase数据库的用户信息部分中放入一个“type”变量(type=家长、学生或教师)。然后,当他们登录时,您检索他们的“类型”。并显示正确的对应界面。

  • 您需要将另外一个
    参数作为类型

  • 其中,如果
    用户的学生登录
    很容易在
    数据库

  • 您需要根据需要创建
    数据库表



很高兴为您提供帮助您需要在firebase
数据库中再添加一个
参数
,接受
类型
。您的意思是用户->类型-->学生-->家长-->教师可以发布
数据库的
结构
,我编辑了我的问题。我的回复会有点晚,因为我现在需要睡觉。Sorry这意味着我必须使用
jRegisterGuardDatabase=FirebaseDatabase.getInstance().getReference().child(“用户”).child(用户学校).child(“类型”).child(“学生”).child(注册表序列号)如果“registeredEmail”与上面的代码相同,则会提示用户进入相应的界面?是的,您是对的!我已经编辑了我的问题并包含了我的登录功能代码。谢谢你=DHey Vishal,你能帮我回答我的另一个问题吗?
    if(task.isSuccessful() && userCode.equals("Student123")){
    //Send user to Student Interface
}else if(task.isSuccessful() && userCode.equals("Parent123")){
    //Send user to Parent Interface
}else if(task.isSuccessful() && userCode.equals("Teacher123")){
    //Send user to Teacher Interface
}
private void loginUser(final String userLoginEmail, final String userLoginPassword) {
        mAuthLogin.signInWithEmailAndPassword(userLoginEmail, userLoginPassword)
                .addOnCompleteListener(this, new OnCompleteListener<AuthResult>() {
                    @Override
                    public void onComplete(@NonNull Task<AuthResult> task) {
                        if(task.isSuccessful()){

                            FirebaseUser currentUser = FirebaseAuth.getInstance().getCurrentUser();
                            String RegisteredUserID = currentUser.getUid();

                            jLoginDatabase = FirebaseDatabase.getInstance().getReference().child("Users").child(RegisteredUserID);

                            jLoginDatabase.addValueEventListener(new ValueEventListener() {
                                @Override
                                public void onDataChange(DataSnapshot dataSnapshot) {
                                    String userType = dataSnapshot.child("userType").getValue().toString();
                                    if(userType.equals("Resident")){
                                        Intent intentResident = new Intent(LoginActivity.this, ResidentActivity.class);
                                        intentResident.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK | Intent.FLAG_ACTIVITY_CLEAR_TASK);
                                        startActivity(intentResident);
                                        finish();
                                    }else if(userType.equals("Guard")){
                                        Intent intentMain = new Intent(LoginActivity.this, SecurityGuardActivity.class);
                                        intentMain.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK | Intent.FLAG_ACTIVITY_CLEAR_TASK);
                                        startActivity(intentMain);
                                        finish();
                                    }else if(userType.equals("Police")){
                                        Intent intentMain = new Intent(LoginActivity.this, PoliceActivity.class);
                                        intentMain.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK | Intent.FLAG_ACTIVITY_CLEAR_TASK);
                                        startActivity(intentMain);
                                        finish();
                                    }else{
                                        Toast.makeText(LoginActivity.this, "Failed Login. Please Try Again", Toast.LENGTH_SHORT).show();
                                        return;
                                    }
                                }

                                @Override
                                public void onCancelled(DatabaseError databaseError) {

                                }
                            });
                        }
                    }
                });
    }