Borang PHP - E-mel Pengesahan dan URL

PHP - Sahkan nama

Kod berikut akan mengesan sama ada medan nama mengandungi huruf dan ruang dengan cara yang mudah Jika nilai medan nama tidak sah, mesej ralat akan dikeluarkan:

$nama = test_input($_POST["nama"]);

jika (!preg_match("/^[a-zA-Z ]*$/" ,$name) )

{
$nameErr = "Hanya huruf dan ruang dibenarkan"; >

preg_match — lakukan padanan ungkapan biasa.

Sintaks:

int preg_match ( string $pattern , string $subject [, array $matches [, int $flags ]] )

Cari rentetan subjek untuk kandungan yang sepadan dengan ungkapan biasa yang diberikan mengikut corak. Jika padanan disediakan, ia akan diisi dengan hasil carian. $matches[0] akan mengandungi teks yang sepadan dengan keseluruhan corak, $matches[1] akan mengandungi teks yang sepadan dengan subcorak pertama yang ditangkap dalam kurungan, dan seterusnya.


Untuk maklumat tentang ungkapan biasa, sila rujuk: Ungkapan Biasa - Tutorial

PHP - E-mel Pengesahan

Kod berikut akan menyemak sama ada alamat e-mel itu sah dengan cara yang mudah. Jika alamat e-mel adalah haram, mesej ralat akan dikeluarkan:


$email = test_input($_POST["email"]);

jika (!preg_match("/([w-]+@[w-]+.[w-]+)/",$email))

{

$emailErr = "Format e-mel tidak sah";} - Sahkan URL

Kod berikut akan semak sama ada alamat URL itu sah (URL operasi ungkapan biasa berikut mengandungi sempang: "-"), jika alamat URL itu menyalahi undang-undang, mesej ralat akan dikeluarkan:


$laman web = test_input($_POST["laman web"]);

jika (!preg_match("/b(?:( ?:https?|ftp)://| www.)[-a-z0-9+&@#/%?=~_|!:,.;]*[-a-z0-9+&@# /%=~_|]/i", $laman web))

{

$websiteErr = " Alamat URL yang tidak sah";

}

PHP - Sahkan Nama, E-mel dan URL

Kodnya adalah seperti berikut:
Instance

<?php
// 定义变量并默认设置为空值
$nameErr = $emailErr = $genderErr = $websiteErr = "";
$name = $email = $gender = $comment = $website = "";
if ($_SERVER["REQUEST_METHOD"] == "POST") {
if (empty($_POST["name"])) {
      $nameErr = "Name is required";
      } else {
         $name = test_input($_POST["name"]);
         // 检测名字是否只包含字母跟空格
         if (!preg_match("/^[a-zA-Z ]*$/",$name)) {
         $nameErr = "只允许字母和空格"; 
         }
     }
   
   if (empty($_POST["email"])) {
      $emailErr = "Email is required";
   } else {
      $email = test_input($_POST["email"]);
      // 检测邮箱是否合法
      if (!preg_match("/([\w\-]+\@[\w\-]+\.[\w\-]+)/",$email)) {
         $emailErr = "非法邮箱格式"; 
      }
   }
     
   if (empty($_POST["website"])) {
      $website = "";
   } else {
      $website = test_input($_POST["website"]);
      // 检测 URL 地址是否合法
     if (!preg_match("/\b(?:(?:https?|ftp):\/\/|www\.)[-a-z0-9+&@#\/%?=~_|!:,.;]*[-a-z0-9+&@#\/%=~_|]/i",$website)) {
         $websiteErr = "非法的 URL 的地址"; 
      }
   }
   if (empty($_POST["comment"])) {
      $comment = "";
   } else {
      $comment = test_input($_POST["comment"]);
   }
   if (empty($_POST["gender"])) {
      $genderErr = "性别是必需的";
   } else {
      $gender = test_input($_POST["gender"]);
   }
}
?>


Meneruskan pembelajaran
||
<!DOCTYPE HTML> <html> <head> <meta charset="utf-8"> <title>PHP中文网</title> <style> .error {color: #FF0000;} </style> </head> <body> <?php // 定义变量并默认设置为空值 $nameErr = $emailErr = $genderErr = $websiteErr = ""; $name = $email = $gender = $comment = $website = ""; if ($_SERVER["REQUEST_METHOD"] == "POST") { if (empty($_POST["name"])) { $nameErr = "Name is required"; } else { $name = test_input($_POST["name"]); // 检测名字是否只包含字母跟空格 if (!preg_match("/^[a-zA-Z ]*$/",$name)) { $nameErr = "只允许字母和空格"; } } if (empty($_POST["email"])) { $emailErr = "Email is required"; } else { $email = test_input($_POST["email"]); // 检测邮箱是否合法 if (!preg_match("/([\w\-]+\@[\w\-]+\.[\w\-]+)/",$email)) { $emailErr = "非法邮箱格式"; } } if (empty($_POST["website"])) { $website = ""; } else { $website = test_input($_POST["website"]); // 检测 URL 地址是否合法 if (!preg_match("/\b(?:(?:https?|ftp):\/\/|www\.)[-a-z0-9+&@#\/%?=~_|!:,.;]*[-a-z0-9+&@#\/%=~_|]/i",$website)) { $websiteErr = "非法的 URL 的地址"; } } if (empty($_POST["comment"])) { $comment = ""; } else { $comment = test_input($_POST["comment"]); } if (empty($_POST["gender"])) { $genderErr = "性别是必需的"; } else { $gender = test_input($_POST["gender"]); } } function test_input($data) { $data = trim($data); $data = stripslashes($data); $data = htmlspecialchars($data); return $data; } ?> <h2>PHP 表单验证实例</h2> <p><span class="error">* 必需字段。</span></p> <form method="post" action="<?php echo htmlspecialchars($_SERVER["PHP_SELF"]);?>"> 名字: <input type="text" name="name"> <span class="error">* <?php echo $nameErr;?></span> <br><br> E-mail: <input type="text" name="email"> <span class="error">* <?php echo $emailErr;?></span> <br><br> 网址: <input type="text" name="website"> <span class="error"><?php echo $websiteErr;?></span> <br><br> 备注: <textarea name="comment" rows="5" cols="40"></textarea> <br><br> 性别: <input type="radio" name="gender" value="female">女 <input type="radio" name="gender" value="male">男 <span class="error">* <?php echo $genderErr;?></span> <br><br> <input type="submit" name="submit" value="Submit"> </form> <?php echo "<h2>您输入的内容是:</h2>"; echo $name; echo "<br>"; echo $email; echo "<br>"; echo $website; echo "<br>"; echo $comment; echo "<br>"; echo $gender; ?> </body> </html>