فیلدهای اجباری فرم (Form Required)
اینجا یاد می گیریم «فیلدهای اجباری فرم» چیست. اجباری یعنی خالی نباشد. پس باید خالی بودن را چک کنیم و پیام خطا بدهیم. این کار بخشی از اعتبارسنجی است.
ایده اصلی فیلدهای اجباری
طبق قوانین منبع، نام، ایمیل و جنسیت اجباری اند. وب سایت و نظر اختیاری اند. پس باید خالی بودن آن ها بررسی شود.
الگوی بررسی اجباری بودن
از متغیرهای خطا مثل $nameErr و تابع test_input استفاده می کنیم. سپس برای هر ورودی، اگر خالی بود، پیام خطا می گذاریم؛ در غیر این صورت، مقدار را پاکسازی می کنیم.
// define variables and set to empty values
$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 (empty($_POST["email"])) {
$emailErr = "Email is required";
} else {
$email = test_input($_POST["email"]);
}
if (empty($_POST["website"])) {
$website = "";
} else {
$website = test_input($_POST["website"]);
}
if (empty($_POST["comment"])) {
$comment = "";
} else {
$comment = test_input($_POST["comment"]);
}
if (empty($_POST["gender"])) {
$genderErr = "Gender is required";
} else {
$gender = test_input($_POST["gender"]);
}
}
نکته: ابتدا صفحه را با REQUEST_METHOD چک کن. فقط وقتی POST بود، اعتبارسنجی کن.
نمایش پیام خطا کنار فیلد
کنار هر فیلد اجباری یک <span class="error"> بگذار. اگر خالی ارسال شد، متن خطا در همان جا دیده می شود.
<form method="post" action="<?php echo htmlspecialchars($_SERVER["PHP_SELF"]); ?>">
Name: <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>
Website:
<input type="text" name="website">
<span class="error"><?php echo $websiteErr; ?></span>
<br><br>
Comment: <textarea name="comment" rows="5" cols="40"></textarea>
<br><br>
Gender:
<input type="radio" name="gender" value="female">Female
<input type="radio" name="gender" value="male">Male
<input type="radio" name="gender" value="other">Other
<span class="error">* <?php echo $genderErr; ?></span>
<br><br>
<input type="submit" name="submit" value="Submit">
</form>
هشدار: برای action حتماً از htmlspecialchars استفاده کن تا از XSS جلوگیری شود.
گام های عملی سریع
- متغیرهای خطا را خالی تعریف کن.
- اگر روش POST بود، ورودی ها را بررسی کن.
- اگر فیلد اجباری خالی بود، پیام خطا بده.
- در غیر این صورت، مقدار را با
test_inputپاکسازی کن. - پیام های خطا را کنار همان فیلد نشان بده.
مطالب مرتبط
برای مقدمه کامل، صفحه اعتبارسنجی فرم را ببین. همچنین برای تکمیل مسیر، اعتبارسنجی ایمیل و URL را پیگیری کن. خود موضوع فیلدهای اجباری فرم هم به عنوان مرجع داخلی ثبت شده است.
جمع بندی سریع
- نام، ایمیل، جنسیت اجباری اند.
- کنار هر فیلد پیام خطا بگذار.
- از
htmlspecialcharsبرای action استفاده کن. - ورودی ها را با
test_inputپاکسازی کن.