PHP Formulärverifiering - Verifiera E-post och URL

Denna sektion visar hur man verifierar namn, e-post och URL.

PHP - Verifiera namn

Följande kod visar en enkel metod för att kontrollera om namn-fältet innehåller bokstäver och blanksteg. Om namn-fältet är ogiltigt, lagras ett felmeddelande:

$name = test_input($_POST["name"]);
if (!preg_match("/^[a-zA-Z ]*$/",$name)) {
  $nameErr = "Endast bokstäver och blanksteg tillåts!"; 
}

Kommentar:preg_match() funktionen söker efter mönster i en sträng, returnerar true om mönstret finns, annars returnerar false.

PHP - Verifiera E-post

Följande kod visar en enkel metod för att kontrollera om e-postadressens syntax är giltig. Om den är ogiltig, lagras ett felmeddelande:

$email = test_input($_POST["email"]);
if (!preg_match("/([\w\-]+\@[\w\-]+\.[\w\-]+)/",$email)) {
  $emailErr = "Ogiltigt e-postformat!"; 
}

PHP - Verifiera URL

Följande kod visas en metod för att kontrollera om URL-adressens syntax är giltig (denna reguljära uttryck tillåter också backslash i URL:en). Om URL-adressens syntax är ogiltig, lagras ett felmeddelande:

$website = test_input($_POST["website"]);
if (!preg_match("/\b(?:(?:https?|ftp):\/\/|www\.)[-a-z0-9+&@#\/%?=~_|!:,.;]*[-a-z0-9+&@#\/%",
=~_|]/i,$website)) {
  $websiteErr = "Ogiltig URL"; 
}

PHP - Verifiera Namn, E-post och URL

Nu är skriptet sådant här:

Exempel

<?php
// Definiera variabler och sätt dem till tomma värden
$nameErr = $emailErr = $genderErr = $websiteErr = "";
$name = $email = $gender = $comment = $website = "";
if ($_SERVER["REQUEST_METHOD"] == "POST") {
  if (empty($_POST["name"])) {
    $nameErr = "Namn är obligatoriskt";
  }
    $name = test_input($_POST["name"]);
    // Kontrollera om namn innehåller bokstäver och blanksteg
    if (!preg_match("/^[a-zA-Z ]*$/",$name)) {
      $nameErr = "Endast bokstäver och blanksteg tillåts"; 
    }
  }
  if (empty($_POST["email"])) {
    $emailErr = "E-post är obligatorisk";
  }
    $email = test_input($_POST["email"]);
    // Kontrollera e-postadress syntaxens giltighet
    if (!preg_match("/([\w\-]+\@[\w\-]+\.[\w\-]+)/",$email)) {
      $emailErr = "Invalid email format"; 
    }
  }
  if (empty($_POST["website"])) {
    $website = "";
  }
    $website = test_input($_POST["website"]);
    // Kontrollera om URL-adressens språk är giltigt (denna reguljära uttryck tillåter också understreck i URL:er)
    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"]);
  }
}
?>

Kör en exempel

Nästa kommer jag att förklara hur du förhindrar att formuläret töms alla inmatningsfält efter att användaren har skickat formuläret.