web-dev-qa-db-fra.com

PHP validation email

PourPHPquelle est la meilleure validation de courrier électronique avec preg,PASereg _ parce que c'est obsolète/supprimé .

Jenondois vérifier si le site Web existe (ce n'est pas comme une sécurité maximale).

J'ai trouvé de nombreuses manières d'utiliser ereg _ mais elles ne sont (évidemment) pas une bonne pratique.

27
Mark Lalor

Je vous suggère d'utiliser le filtre FILTER_VALIDATE_EMAIL:

if (filter_var($email, FILTER_VALIDATE_EMAIL)) {
    //valid
}

Vous pouvez également utiliser son expression régulière directement:

"/^(?!(?:(?:\\x22?\\x5C[\\x00-\\x7E]\\x22?)|(?:\\x22?[^\\x5C\\x22]\\x22?)){255,})(?!(?:(?:\\x22?\\x5C[\\x00-\\x7E]\\x22?)|(?:\\x22?[^\\x5C\\x22]\\x22?)){65,}@)(?:(?:[\\x21\\x23-\\x27\\x2A\\x2B\\x2D\\x2F-\\x39\\x3D\\x3F\\x5E-\\x7E]+)|(?:\\x22(?:[\\x01-\\x08\\x0B\\x0C\\x0E-\\x1F\\x21\\x23-\\x5B\\x5D-\\x7F]|(?:\\x5C[\\x00-\\x7F]))*\\x22))(?:\\.(?:(?:[\\x21\\x23-\\x27\\x2A\\x2B\\x2D\\x2F-\\x39\\x3D\\x3F\\x5E-\\x7E]+)|(?:\\x22(?:[\\x01-\\x08\\x0B\\x0C\\x0E-\\x1F\\x21\\x23-\\x5B\\x5D-\\x7F]|(?:\\x5C[\\x00-\\x7F]))*\\x22)))*@(?:(?:(?!.*[^.]{64,})(?:(?:(?:xn--)?[a-z0-9]+(?:-[a-z0-9]+)*\\.){1,126}){1,}(?:(?:[a-z][a-z0-9]*)|(?:(?:xn--)[a-z0-9]+))(?:-[a-z0-9]+)*)|(?:\\[(?:(?:IPv6:(?:(?:[a-f0-9]{1,4}(?::[a-f0-9]{1,4}){7})|(?:(?!(?:.*[a-f0-9][:\\]]){7,})(?:[a-f0-9]{1,4}(?::[a-f0-9]{1,4}){0,5})?::(?:[a-f0-9]{1,4}(?::[a-f0-9]{1,4}){0,5})?)))|(?:(?:IPv6:(?:(?:[a-f0-9]{1,4}(?::[a-f0-9]{1,4}){5}:)|(?:(?!(?:.*[a-f0-9]:){5,})(?:[a-f0-9]{1,4}(?::[a-f0-9]{1,4}){0,3})?::(?:[a-f0-9]{1,4}(?::[a-f0-9]{1,4}){0,3}:)?)))?(?:(?:25[0-5])|(?:2[0-4][0-9])|(?:1[0-9]{2})|(?:[1-9]?[0-9]))(?:\\.(?:(?:25[0-5])|(?:2[0-4][0-9])|(?:1[0-9]{2})|(?:[1-9]?[0-9]))){3}))\\]))$/iD"

Mais dans ce cas, si un bogue est trouvé dans l'expression régulière, vous devrez mettre à jour votre programme au lieu de mettre à jour PHP.

78
Artefacto

À moins que vous ne souhaitiez utiliser une très très longues expressions régulières vous rencontrerez des adresses électroniques valides non couvertes (pensez à Unicode). Les fausses adresses e-mail seront également considérées comme valides. Quel est donc l'intérêt de valider si vous pouvez simplement écrire [email protected] et vous en tirer?

Le meilleur moyen de valider des adresses électroniques consiste à envoyer un courrier électronique de confirmation avec un lien sur lequel cliquer. Cela ne fonctionnera que si l'adresse e-mail est valide: facile, et pas besoin d'utiliser regex.

3
nico
function check_email($check) {
$expression = "/^[a-zA-Z0-9._-]+@[a-zA-Z0-9._-]+\.([a-zA-Z]{2,4})$/";
if (preg_match($expression, $check)) {
    return true;
} else {
    return false;
} 
}

Appelez-le si () condition comme exemple ci-dessous: 

if(!check_email($_REQUEST['ContactEmail'])){
  $register_error ="Enter the correct email address!<br />";
  $reg_error=1; 
}
0
Gaurav Gupta