web-dev-qa-db-fra.com

Android Email Validation sur EditText

bonjour tout le monde j'ai un edittext et je voudrais écrire un email de validation dans mon Editttext c'est un code xml

<EditText
        Android:id="@+id/mail"
        Android:layout_width="match_parent"
        Android:layout_height="48dp"
        Android:layout_alignLeft="@+id/phone"
        Android:layout_below="@+id/phone"
        Android:layout_marginRight="33dp"
        Android:layout_marginTop="10dp"
        Android:background="@drawable/edit_background"
        Android:ems="10"
        Android:hint="E-Mail"
        Android:inputType="textEmailAddress"
        Android:paddingLeft="20dp"
        Android:textColor="#7e7e7e"
        Android:textColorHint="#7e7e7e" >
    </EditText>

et ceci est un code Java

emailInput = mail.getText().toString().trim();

    emailPattern = "^[_A-Za-z0-9-]+(\\.[_A-Za-z0-9-]+)*@[A-Za-z0-9]+(\\.[A-Za-z0-9]+)*(\\.[A-Za-z]{2,})$";


    if (emailInput.matches(emailPattern)) {
            Toast.makeText(getActivity(), "valid email address",
                    Toast.LENGTH_SHORT).show();


        } else {
            Toast.makeText(getActivity(), "Invalid email address",
                    Toast.LENGTH_SHORT).show();
            mail.setBackgroundResource(R.drawable.edit_red_line);
        }

je ne peux pas valider. Le message de pain grillé est toujours "Adresse électronique non valide" Qu'est-ce que je fais mal? si quelqu'un connaît la solution s'il vous plaît aidez-moi

21
BekaKK

Pourquoi ne pas utiliser:

public final static boolean isValidEmail(CharSequence target) {
  return !TextUtils.isEmpty(target) && Android.util.Patterns.EMAIL_ADDRESS.matcher(target).matches();
}

Comme suggéré ici .

87
Daniel Zolnai

Je poste une réponse très simple et facile de validation de courrier électronique sans utiliser aucun modèle de chaîne.

1.Sélectionnez le port d'écoute sur le bouton ....

 button_resetPassword.setOnClickListener(new View.OnClickListener()
    {
        @Override
        public void onClick(View v)
        {
            CharSequence temp_emilID=username.getText().toString();//here username is the your edittext object...
            if(!isValidEmail(temp_emilID))
            {
                username.requestFocus();
                username.setError("Enter Correct Mail_ID ..!!");
                     or
                Toast.makeText(getApplicationContext(), "Enter Correct Mail_ID", Toast.LENGTH_SHORT).show();

            }
            else
           {
              correctMail.. 
             //Your action...

           }

         });

2.call isValidEmail () i.e ..

   public final static boolean isValidEmail(CharSequence target)
   {
    if (TextUtils.isEmpty(target))
    {
        return false;
    } else {
        return Android.util.Patterns.EMAIL_ADDRESS.matcher(target).matches();
    }
 }

J'espère que cela vous sera utile ...

2
sachin pangare

Android Email Validation Plus simple

   String validemail= "[a-zA-Z0-9\\+\\.\\_\\%\\-\\+]{1,256}" +

                        "\\@" +

                        "[a-zA-Z0-9][a-zA-Z0-9\\-]{0,64}" +

                        "(" +

                        "\\." +

                        "[a-zA-Z0-9][a-zA-Z0-9\\-]{0,25}" +

                        ")+";

               String emal=email.getText().toString();

                Matcher matcherObj = Pattern.compile(validemail).matcher(emal);



                        if (matcherObj.matches()) {

                               Toast.makeText(getApplicationContext(), "enter 

all details", Toast.LENGTH_SHORT).show();

                        }

                        else 
{
                            Toast.makeText(getApplicationContext(),"please enter 

valid email",Toast.LENGTH_SHORT).show();

                        }
1
Raseem Ayatt

Essayez le code suivant:

public final static boolean isValidEmail(CharSequence target) {
    return !TextUtils.isEmpty(target) && Android.util.Patterns.EMAIL_ADDRESS.matcher(target).matches();
}

Cela fonctionne bien.

1
Shamir Kp

J'avais une requête dans le modèle de courrier électronique pour plus d'une validation d'ID de courrier électronique et pour un seul courrier électronique. Je l'ai résolue en utilisant:

public static final String patter_emails="^(\\s*,?\\s*[0-9a-za-z]([-.\\w]*[0-9a-za-z])*@([0-9a-za-z][-\\w]*[0-9a-za-z]\\.)+[a-za-z]{2,9})+\\s*$";
public static final String patter_email="^(\\s*[0-9a-za-z]([-.\\w]*[0-9a-za-z])*@([0-9a-za-z][-\\w]*[0-9a-za-z]\\.)+[a-za-z]{2,9})+\\s*$";

Ces exemples sont utilisés pour les modèles sous Java et Android.

vérifiez ceci en utilisant:

test de modèle: rubular.com

0
ankit

voici un code complet pour les validations de connexion ......

public class LoginActivity extends AppCompatActivity {
private static final String TAG = "LoginActivity";
private static final int REQUEST_SIGNUP = 0;

@Bind(R.id.input_email) EditText _emailText;
@Bind(R.id.input_password) EditText _passwordText;
@Bind(R.id.btn_login) Button _loginButton;
@Bind(R.id.link_signup) TextView _signupLink;

@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_login);
    ButterKnife.bind(this);

    _loginButton.setOnClickListener(new View.OnClickListener() {

        @Override
        public void onClick(View v) {
            login();
        }
    });

    _signupLink.setOnClickListener(new View.OnClickListener() {

        @Override
        public void onClick(View v) {
            // Start the Signup activity
            Intent intent = new Intent(getApplicationContext(), SignupActivity.class);
            startActivityForResult(intent, REQUEST_SIGNUP);
            finish();
            overridePendingTransition(R.anim.Push_left_in, R.anim.Push_left_out);
        }
    });
}

public void login() {
    Log.d(TAG, "Login");

    if (!validate()) {
        onLoginFailed();
        return;
    }

    _loginButton.setEnabled(false);

    final ProgressDialog progressDialog = new ProgressDialog(LoginActivity.this,
            R.style.AppTheme_Dark_Dialog);
    progressDialog.setIndeterminate(true);
    progressDialog.setMessage("Authenticating...");
    progressDialog.show();

    String email = _emailText.getText().toString();
    String password = _passwordText.getText().toString();

    // TODO: Implement your own authentication logic here.

    new Android.os.Handler().postDelayed(
            new Runnable() {
                public void run() {
                    // On complete call either onLoginSuccess or onLoginFailed
                    onLoginSuccess();
                    // onLoginFailed();
                    progressDialog.dismiss();
                }
            }, 3000);
}


@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
    if (requestCode == REQUEST_SIGNUP) {
        if (resultCode == RESULT_OK) {

            // TODO: Implement successful signup logic here
            // By default we just finish the Activity and log them in automatically
            this.finish();
        }
    }
}

@Override
public void onBackPressed() {
    // Disable going back to the MainActivity
    moveTaskToBack(true);
}

public void onLoginSuccess() {
    _loginButton.setEnabled(true);
    finish();
}

public void onLoginFailed() {
    Toast.makeText(getBaseContext(), "Login failed", Toast.LENGTH_LONG).show();

    _loginButton.setEnabled(true);
}

public boolean validate() {
    boolean valid = true;

    String email = _emailText.getText().toString();
    String password = _passwordText.getText().toString();

    if (email.isEmpty() || !Android.util.Patterns.EMAIL_ADDRESS.matcher(email).matches()) {
        _emailText.setError("enter a valid email address");
        valid = false;
    } else {
        _emailText.setError(null);
    }

    if (password.isEmpty() || password.length() < 4 || password.length() > 10) {
        _passwordText.setError("between 4 and 10 alphanumeric characters");
        valid = false;
    } else {
        _passwordText.setError(null);
    }

    return valid;
}

}

0
Tabish khan
Android.util.Patterns.EMAIL_ADDRESS.matcher(target).matches()
0
ivap arht
private void isValidEmail(String email_id) {

        if (email_id == null){
            checkTextView.setVisibility(View.VISIBLE);
            checkTextView.setText(LocaleController.getString("EnterValidEmail", R.string.EnterValidEmail));
            return;
        }
        if (Android.util.Patterns.EMAIL_ADDRESS.matcher(email_id).matches()) {
            checkTextView.setVisibility(View.GONE);
        } else {
            checkTextView.setVisibility(View.VISIBLE);
            checkTextView.setText(LocaleController.getString("EnterValidEmail", R.string.EnterValidEmail));
        }

Prenez un textView ex.checkTextView et validez lorsque l'e-mail est valide, puis la visualisation du texte a disparu, sinon le message s'affiche. 

0
rajeev omar

Utilisez cette fonction pour valider l’identifiant email:

 private boolean validateEmaillId(String emailId){

    return Pattern.compile("^(([\\w-]+\\.)+[\\w-]+|([a-zA-Z]{1}|[\\w-]{2,}))@"
            + "((([0-1]?[0-9]{1,2}|25[0-5]|2[0-4][0-9])\\.([0-1]?"
            + "[0-9]{1,2}|25[0-5]|2[0-4][0-9])\\."
            + "([0-1]?[0-9]{1,2}|25[0-5]|2[0-4][0-9])\\.([0-1]?"
            + "[0-9]{1,2}|25[0-5]|2[0-4][0-9])){1}|"
            + "([a-zA-Z]+[\\w-]+\\.)+[a-zA-Z]{2,4})$").matcher(emailId).matches();
}
0
Vishal Vaishnav