PHP preg_match pattern является подстрокой темы - PullRequest
0 голосов
/ 14 мая 2019

Я хочу проверить, имеет ли вход тип 1234567 (7 цифр).Я использую

preg_match($pattern,$subject);

, где

$pattern = '/^[0-9]{7}$/';

Однако я получаю 1 для случая, когда объектом является

L-8987765

, который я не хочу.Как я могу преодолеть это?

   function isDocid($documento_id)
      {
       $subject = pg_escape_literal($documento_id);
       $pattern1 = '/^[0-9]{7}$/';

            if (preg_match($pattern1, $subject) === 1) 
            {
            return 1;
            }
            else
            {
            return 0;
            }}

$test_carta = isDocid('L-8987765');
echo('<p> ja existe docid   '. $test_carta  .'</p>');

Я ожидаю: ja existe docid 0

1 Ответ

0 голосов
/ 14 мая 2019

С документация (курсив мой):

pg_escape_literal() экранирует литерал для запросов к базе данных PostgreSQL.Возвращает экранированный литерал в формате PostgreSQL.pg_escape_literal() добавляет кавычки до и после данных .

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

function isDocid($documento_id)
{
   return (preg_match('/^[0-9]{7}$/', $documento_id) === 1) ? 1 : 0;
}

$test_carta = isDocid('L-8987765');
echo('<p> ja existe docid   '. $test_carta  .'</p>');
...