PHP Валидация формы - Валидация E-mail и URL

Этот раздел показывает, как проверить имя, адрес электронной почты и URL.

PHP - Проверка имени

Ниже приведен пример кода, который проверяет, содержит ли поле name буквы и пробельные символы. Если поле name не валидно, хранится сообщение об ошибке:

$name = test_input($_POST["name"]);
if (!preg_match("/^[a-zA-Z ]*$/",$name)) {
  $nameErr = "Разрешены только буквы и пробельные символы!"; 
}

Комментарий:Функция preg_match() ищет шаблон в строке, возвращает true, если шаблон существует,否则 false.

PHP - Проверка E-mail

Ниже приведен пример кода, который проверяет грамматику адреса электронной почты. Если грамматика адреса электронной почты неправильна, хранится сообщение об ошибке:

$email = test_input($_POST["email"]);
if (!preg_match("/([\w\-]+\@[\w\-]+\.[\w\-]+)/",$email)) {
  $emailErr = "Неправильный формат email"; 
}

PHP - Проверка URL

Ниже приведен пример кода, который проверяет грамматику адреса URL. Если грамматика адреса URL неправильна, хранится сообщение об ошибке:

$website = test_input($_POST["website"]);
if (!preg_match("/\b(?:(?:https?|ftp):\/\/|www\.)[-a-z0-9+&@#\/%?=~_|!:,.;]*[-a-z0-9+&@#\/%",
=~_|]/i,$website)) {
  $websiteErr = "Неправильный URL"; 
}

PHP - Проверка Name, E-mail и URL

Теперь скрипт такой:

Пример

<?php
// Определение переменных и установление их в пустое значение
$nameErr = $emailErr = $genderErr = $websiteErr = "";
$name = $email = $gender = $comment = $website = "";
if ($_SERVER["REQUEST_METHOD"] == "POST") {
  if (empty($_POST["name"])) {
    $nameErr = "Имя обязательно";
  }
    $name = test_input($_POST["name"]);
    // Проверка содержится ли имя из букв и пробельных символов
    if (!preg_match("/^[a-zA-Z ]*$/",$name)) {
      $nameErr = "Разрешены только буквы и пробельные символы"; 
    }
  }
  if (empty($_POST["email"])) {
    $emailErr = "Email обязателен";
  }
    $email = test_input($_POST["email"]);
    // Проверка грамматики адреса электронной почты
    if (!preg_match("/([\w\-]+\@[\w\-]+\.[\w\-]+)/",$email)) {
      $emailErr = "Invalid email format"; 
    }
  }
  if (empty($_POST["website"])) {
    $website = "";
  }
    $website = test_input($_POST["website"]);
    // Проверка того, является ли адрес URL языковым адресом (этот регулярный выражение также позволяет использовать подстрочные знаки в URL)
    if (!preg_match("/\b(?:(?:https?|ftp):\/\/|www\.)[-a-z0-9+&@#\/%?=~_|!:,.;]*[-a-z0-9+&@#\/%",
    =~_|]/i,$website)) {
      $websiteErr = "Invalid URL"; 
    }
  }
  if (empty($_POST["comment"])) {
    $comment = "";
  }
    $comment = test_input($_POST["comment"]);
  }
  if (empty($_POST["gender"])) {
    $genderErr = "Gender is required";
  }
    $gender = test_input($_POST["gender"]);
  }
}
?>

Запуск примера

Далее я объясню, как предотвратить очистку всех полей ввода формы после ее отправки пользователем.