2011-06-07 3 views
2

Я создаю контактную форму с использованием PHP с проверкой jQuery, и я хотел, чтобы они оба имели один и тот же шаблон электронной почты. Я посмотрел в исходный код плагина валидации и нашел это:преобразование javascript regex в php preg_match

/^((([a-z]|\d|[!#\$%&'\*\+\-\/=\?\^_`{\|}~]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])+(\.([a-z]|\d|[!#\$%&'\*\+\-\/=\?\^_`{\|}~]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])+)*)|((\x22)((((\x20|\x09)*(\x0d\x0a))?(\x20|\x09)+)?(([\x01-\x08\x0b\x0c\x0e-\x1f\x7f]|\x21|[\x23-\x5b]|[\x5d-\x7e]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(\\([\x01-\x09\x0b\x0c\x0d-\x7f]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]))))*(((\x20|\x09)*(\x0d\x0a))?(\x20|\x09)+)?(\x22)))@((([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.)+(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.?$/i 

https://github.com/jzaefferer/jquery-validation/blob/1.8.1/jquery.validate.js#L1008

Я попытался подключить, что в моей существующей проверки формы PHP, но он больше не признает ничего. Я попробовал различные онлайн-инструменты для тестирования регулярных выражений, а некоторые сказали мне, что произошла ошибка. Большинство из них не сказал ничего больше, но один сказал ...

preg_match() [function.preg матча]: Компиляция не удалось: PCRE не поддерживает \ L, \ л, \ N, \ U, или \ и по смещению 45

http://www.solmetra.com/scripts/regex/index.php

Я искал юникода капитала L, который u004C, но я не могу найти \ u004C в регулярном выражении, так что я не знаю, что это неправильно или как это исправить.

ответ

1

Я согласен с Алексом - не использовать регулярное выражение для этого.

Но для полноты, это то, что это (ужасно) регулярное выражение будет выглядеть в PHP:

/^((([a-z]|\d|[!#$%&\'*+\-\/=?\^_`{|}~]|[\x{00A0}-\x{D7FF}\x{F900}-\x{FDCF}\x{FDF0}-\x{FFEF}])+(\.([a-z]|\d|[!#$%&\'*+\-\/=?\^_`{|}~]|[\x{00A0}-\x{D7FF}\x{F900}-\x{FDCF}\x{FDF0}-\x{FFEF}])+)*)|((\x22)((((\x20|\x09)*(\x0d\x0a))?(\x20|\x09)+)?(([\x01-\x08\x0b\x0c\x0e-\x1f\x7f]|\x21|[\x23-\x5b]|[\x5d-\x7e]|[\x{00A0}-\x{D7FF}\x{F900}-\x{FDCF}\x{FDF0}-\x{FFEF}])|(\\\\([\x01-\x09\x0b\x0c\x0d-\x7f]|[\x{00A0}-\x{D7FF}\x{F900}-\x{FDCF}\x{FDF0}-\x{FFEF}]))))*(((\x20|\x09)*(\x0d\x0a))?(\x20|\x09)+)?(\x22)))@((([a-z]|\d|[\x{00A0}-\x{D7FF}\x{F900}-\x{FDCF}\x{FDF0}-\x{FFEF}])|(([a-z]|\d|[\x{00A0}-\x{D7FF}\x{F900}-\x{FDCF}\x{FDF0}-\x{FFEF}])([a-z]|\d|-|\.|_|~|[\x{00A0}-\x{D7FF}\x{F900}-\x{FDCF}\x{FDF0}-\x{FFEF}])*([a-z]|\d|[\x{00A0}-\x{D7FF}\x{F900}-\x{FDCF}\x{FDF0}-\x{FFEF}])))\.)+(([a-z]|[\x{00A0}-\x{D7FF}\x{F900}-\x{FDCF}\x{FDF0}-\x{FFEF}])|(([a-z]|[\x{00A0}-\x{D7FF}\x{F900}-\x{FDCF}\x{FDF0}-\x{FFEF}])([a-z]|\d|-|\.|_|~|[\x{00A0}-\x{D7FF}\x{F900}-\x{FDCF}\x{FDF0}-\x{FFEF}])*([a-z]|[\x{00A0}-\x{D7FF}\x{F900}-\x{FDCF}\x{FDF0}-\x{FFEF}])))\.?$/iu 

Перевод RegexBuddy.

+0

После некоторых исследований я обнаружил, что filter_validate_email не полностью соответствует rfc2822. Поскольку я не хочу, чтобы 2 проверки были разными, я думаю, что я пойду с этим вместо этого. Если бы я использовал чистую проверку php, думаю, я бы использовал filter_var(). http://bugs.php.net/bug.php?id=43402 http://bugs.php.net/49576 – gavsiu

2

При использовании PHP, не используйте регулярное выражение, используйте filter_var() ...

$validEmail = filter_var($email, FILTER_VALIDATE_EMAIL); 
+0

будет filter_var() быть более строгим, чем регулярное выражение там? если у людей есть javascript, я не хочу, чтобы проверка php была «ударилась» – gavsiu

Смежные вопросы