web-dev-qa-db-ja.com

Android-Firebase-さまざまなタイプのユーザーログイン

目的

さまざまなタイプのユーザーがそれぞれのインターフェースにサインインできるようにする

説明

  • ユーザーのタイプ(3):

    1. 学生
    2. 先生
  • 各ユーザーはFirebase Authenticationメールを介して登録されます

  • 各ユーザーは、他のユーザーと異なる場合、各インターフェースとしてそれぞれのインターフェースにアクセスできる必要があります

  • 各ユーザーは、Firebaseデータベース内のそれぞれの子ノードとともに既に保存されています。たとえば、「ユーザー」の下に「学校」があり、その下に「学生」、「親」、「先生」などのユーザータイプがあります。

視覚化目的のデータベース

  • ユーザー

->学校

------>学生

------>親

------>教師

enter image description here

問題

現在Firebase Authentication Emailを使用しているため、どのユーザーがどのユーザーであるかを区別できません。

アプリにログインするときにユーザーが選択する3種類のユーザーを含むラジオボタンを作成するという提案されたソリューション。つまり、ユーザーはメールアドレスとパスワードを入力し、ユーザーのタイプを選択してサインインする必要があります。

この問題は、「生徒」ユーザーがラジオボタンで「親」または「教師」を選択し、生徒のメールを使用してサインインした場合、アプリは「生徒」のメールを「親」または「先生"

LoginActivityクラス

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"をハードコーディングする必要があると思っていました。

たとえば、各ユーザーとそれぞれの「ユーザーコード」

"Student" = "Student123"

"親" = "親123"

"Teacher" = "Teacher123"

コード例は次のようになります

    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
}

UserCodeはEditTextになるため、このアイデアの概念はラジオボタンの概念と似ていますが、「userCode」が「セカンダリ」パスワードとして機能するため、セキュリティが向上します。ユーザーは私(管理者)からのみそれを知っています。あなたの考えをください


>>>>>>>>>>>>>>>>>>>>>>>>>>> SOLUTION <<<<<<<<<<<<<<<< <<<<<<<<<<<<

ソリューション-説明

ユーザーがFirebase Email Authenticationを介してAuthenticatedになった後、認証されたユーザーが「学生」として登録されているかどうかを判断する「loginUser」関数内でIf elseステートメントが実行されます。 「親」または「教師」。

  • 注意

登録時に、ユーザーの「userType」変数を登録します。 「userType」はデータベースツリー内に格納されます。これにより、ログインセッション中にユーザーのタイプを確認するためにそれを呼び出すことができます。

ソリューション-サンプルコード

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) {

                                }
                            });
                        }
                    }
                });
    }
10

必要なのは、ユーザーがアプリに初めてサインアップするときに、ユーザーが保護者、生徒、または教師であることを確認する方法です。その後、Firebaseデータベースのユーザー情報セクションに「type」変数を配置します(type = Parent、student、またはTeacher)。次に、彼らがログインすると、あなたは彼らの「タイプ」を取得します。そして、対応する正しいインターフェースを表示します。

  • あなたはもう1つ取る必要があります_parameter as a type_

  • _user's student login_の場合、differentiatabledatabaseにするのは簡単です。

  • 必要に応じて_database table_を作成する必要があります

あなたを助けて幸せ

2
Vishal Yadav