Сбой PHP-выражений при переходе с ereg на preg_match
У меня есть класс, который использует PHP ereg()
что устарело. Глядя на PHP.net, я думал, что могу просто уйти и перейти на preg_match()
Но я получаю ошибки с регулярными выражениями, или они терпят неудачу!!
Вот два примера:
function input_login() {
if (ereg("[^-_@\.A-Za-z0-9]", $input_value)) { // WORKS
// if (preg_match("[^-_@\.A-Za-z0-9]", $input_value)) { // FAILS
echo "is NOT alphanumeric with characters - _ @ . allowed";
}
}
// validate email
function validate_email($email) {
// return eregi("^[_\.0-9a-zA-Z-]+@([0-9a-zA-Z][0-9a-zA-Z-]+\.)+[a-zA-Z]{2,6}$", $email); // FAILS
}
3 ответа
Вы забыли разделители:
if (preg_match("/[^-_@.A-Za-z0-9]/", $input_value))
Кроме того, точку не нужно экранировать внутри класса символов.
Для вашей функции проверки вам нужно сделать регулярное выражение без учета регистра, используя i
модификатор:
return preg_match('/^[_.0-9a-zA-Z-]+@([0-9a-zA-Z][0-9a-zA-Z-]+\.)+[a-zA-Z]{2,6}$/i', $email)
Я больше не могу подавлять подозрение, что людям просто не нравится мой +@example.org
адрес электронной почты (я изменил только правую часть). Это абсолютно нормальный адрес, он действителен, короток и прост для ввода. Просто людям это не нравится! Никто не может зарегистрироваться на любой странице, используя эту почту.
Итак, почему бы не быть милым и использовать расширение фильтра PHPs для проверки почты или использовать PCRE, который определенно разрешает использовать все действительные электронные письма (кроме только @[]):
/^[^@]+@(?:[^.]+\.)+[A-Za-z]{2,6}$/
Спасибо за сохранение моей электронной почты, это умирающий вид!