Validation de L'email Android sur EditText

Bonjour tout le monde, j'ai un edittext et je voudrais écrire la validation e-mail dans mon EditText 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 c'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 la validation.le message toast est toujours " adresse email invalide" ce que je fais mal? si quelqu'un connaît la solution s'il vous plaît aidez-moi

21
demandé sur BekaKK 2014-07-26 14:09:02

11 réponses

Pourquoi ne pas utiliser:

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

Comme l'a suggéré ici.

86
répondu Daniel Zolnai 2017-05-23 12:03:04

je poste réponse très simple et facile de la validation d'email sans utiliser n'importe quel modèle de chaîne de caractères.

1.Situé sur écouteur de clics 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.appeler 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 ça sera utile pour vous...

2
répondu sachin pangare 2016-04-26 20:20:54

Validation du courriel Android de la façon la 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
répondu Raseem Ayatt 2015-12-03 12:13:03

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 très bien.

1
répondu Shamir Kp 2016-03-09 07:15:59

android.util.Modèle.ADRESSE.matcher(cible).correspond à()

0
répondu ivap arht 2015-07-23 17:10:10

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
répondu Tabish khan 2017-05-03 07:59:31

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 exemple de textView.checkTextView et valider lorsque l'email est valide, alors le textview est parti sinon il affiche le message

0
répondu rajeev omar 2017-06-19 11:57:24

Utilisez cette fonction pour valider l'email id:

 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
répondu Vishal Vaishnav 2017-07-15 07:22:37

j'ai eu une requête en email pattern pour plus d'un email ID de validation et pour un seul Email ID.Je l'ai résolu 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*$";

ceux-ci ci ci-dessus est utilisé pour le modèle en Java et Android à la fois.

vérifier en utilisant:

test de patron: rubular.com

0
répondu ankit 2017-10-11 09:08:44

Essayez de code ci-dessous:

juste appeler la méthode ci-dessous comme,

if(emailValidator(mail.getText().toString())){
Toast.makeText(getActivity(), "valid email address",
                    Toast.LENGTH_SHORT).show();

}else{
Toast.makeText(getActivity(), "invalid email address",
                    Toast.LENGTH_SHORT).show();

}

    public static boolean emailValidator(final String mailAddress) {

            Pattern pattern;
            Matcher matcher;

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

            pattern = Pattern.compile(EMAIL_PATTERN);
            matcher = pattern.matcher(mailAddress);
            return matcher.matches();

        }
-1
répondu Pratik Dasa 2014-07-26 10:10:49

Assignez une variable String pour stocker la valeur de ce texte D'édition:

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

utilisez setError dans votre texte D'édition:

if(!isValidEmail(emailInput)){
   mail.setError("Invalid"); /*"Invalid Text" or something like getString(R.string.Invalid)*/
   mail.requestFocus();
}

Créer une méthode pour vérifier le courrier électronique:

private boolean isValidEmail(String emailInput) {
    String EMAIL_PATTERN = "^[_A-Za-z0-9-\+]+(\.[_A-Za-z0-9-]+)*@"
            + "[A-Za-z0-9-]+(\.[A-Za-z0-9]+)*(\.[A-Za-z]{2,})$";

    Pattern pattern = Pattern.compile(EMAIL_PATTERN);
    Matcher matcher = pattern.matcher(emailInput);
    return matcher.matches();
}
-1
répondu Mifreitas10 2015-10-07 05:54:32