Сбой PHP-выражений при переходе с ereg на preg_match - PullRequest
1 голос
/ 07 июля 2010

У меня есть класс, который использует 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 ]

3 голосов
/ 07 июля 2010

Вы забыли разделители:

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)
1 голос
/ 07 июля 2010

Я больше не могу подавить подозрение, что людям просто не нравится мой +@example.org электронный адрес (я изменил только правую часть). Это абсолютно нормальный адрес, он действителен, короток и прост для ввода. Просто людям это не нравится! Нельзя зарегистрироваться на любой странице, используя эту почту.

Итак, почему бы не быть милым и использовать расширение PHPs Filter для проверки почты или использовать PCRE, который определенно позволяет использовать все действительные электронные письма (кроме только @ []):

/^[^@]+@(?:[^.]+\.)+[A-Za-z]{2,6}$/

Спасибо за сохранение моей электронной почты, это умирающий вид!

0 голосов
/ 07 июля 2010

попробуй preg_match("/[^-_@\.A-Za-z0-9]/", $input_value)

...