Всем привет!
А не подскажет ли кто, каким макаром прописать в preg_match регулярку для фильтрации логина, чтобы возможен был лишь одни пробел между двумя текстовыми фрагментами логина. Ну, типа, "Fat Joe" или "iron cunt"? :)
Можно ли так:
после обработки trim($_POST[user]) написать:
if (preg_match("/[0-9a-zA-Zа-яА-Я-_ {1}]/+$")){ выкрутасы с логином...}... ?
То есть, чтобы был ОДИН пробел между двух строк.
Спасибо.
Примечание:
Veseloff, thnks! But... Но ведь квантификатор "+" подразумевает ОБЯЗАТЕЛЬНОЕ наличие символов после первой части логина.
Т.е., правильнее было бы так:
preg_match("~^[a-zA-Zа-яА-Я0-9-_]+[ ]{0,1}[a-zA-Zа-яА-Я0-9-_]*$~", $str) ? (Последний не "+", а "*") Правильно?
Примечание:
Или, для читабельности: preg_match("~^[a-zA-Zа-яА-Я0-9-_]+[\s]{0,1}[a-zA-Zа-яА-Я0-9-_]*$~", $str)
Во всяком случае, большущее спасибо, Veseloff!!
Примечание:
Еще вернее:
preg_match("~^[a-zA-Zа-яА-Я0-9-_]+[\s]{0,1}*[a-zA-Zа-яА-Я0-9-_]*$~", $str)
Так как, если логин будет состоять только из одного "слова", то и пробел, и второе "слово" станут ненужными и мы после их регулярок ставим не "+", а "*".
Я правильно понял?
Примечание:
Dorantor, спасибо! А пробел в конце можно обрезать trim($str), не так ли?
RPI.su - самая большая русскоязычная база вопросов и ответов. Наш проект был реализован как продолжение популярного сервиса otvety.google.ru, который был закрыт и удален 30 апреля 2015 года. Мы решили воскресить полезный сервис Ответы Гугл, чтобы любой человек смог публично узнать ответ на свой вопрос у интернет сообщества.
Все вопросы, добавленные на сайт ответов Google, мы скопировали и сохранили здесь. Имена старых пользователей также отображены в том виде, в котором они существовали ранее. Только нужно заново пройти регистрацию, чтобы иметь возможность задавать вопросы, или отвечать другим.
Чтобы связаться с нами по любому вопросу О САЙТЕ (реклама, сотрудничество, отзыв о сервисе), пишите на почту [email protected]. Только все общие вопросы размещайте на сайте, на них ответ по почте не предоставляется.