ABOUT ME

-

Today
-
Yesterday
-
Total
-
  • [PHP] 19. Form Required - PHP 강좌, PHP5
    Web/PHP 2015. 6. 13. 13:49


    PHP 5 Forms - Required Fields





    1. PHP - Required Fields

     이전 장에서의 유효성 규칙 테이블에서 보면, "Name", "E-mail", "Gender" 필드는 필수적입니다. 이러한 필드들은 공백이여서는 안되고 HTML 서식에서 채워져야 합니다.



     

    FieldValidation Rules
    NameRequired. + Must only contain letters and whitespace
    E-mailRequired. + Must contain a valid email address (with @ and .)
    WebsiteOptional. If present, it must contain a valid URL
    CommentOptional. Multi-line input field (textarea)
    GenderRequired. Must select one

    [ 출처: W3Schools ]






     아래 코드에 보면 몇 가지 새로운 변수를 추가하였습니다: $nameErr, $emailErr, $genderErr, $websiteErr.


     이러한 에러 변수는 필수적인 필드들을 위한 에러 메세지를 담을 것 입니다. 


     또한 각 $_POST 변수에 대한 if else 문을 추가하였습니다. 이 체크는 $_POST 변수가 공백인지 검사합니다.


     공백이라면, 에러메세지는 각기 다른 에러 변수에 저장될 것이며, 


     그게 아니라면, test_input() 함수를 통하여 사용자 입력 데이터가 전송되어 질 것 입니다.



    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    <?php
    // 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"]);
      }
    }
    ?>
    cs








    2. PHP - Display The Error Messages

     그러고나서 HTML 서식에, 각 필수적인 필드 뒤에 작은 스크립트들을 추가 할 것입니다.


     이 스크립트들은 필요로 한다면 올바른 에러 메시지를 생성해내는 스크립트입니다.



    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
     
    <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>
    <label>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
    <span class="error">* <?php echo $genderErr;?></span>
    <br><br>
    <input type="submit" name="submit" value="Submit"
     
    </form>
     
    cs






    완성 예제:



    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
     
    <!DOCTYPE HTML
    <html>
    <head>
    <style>
    .error {color: #FF0000;}
    </style>
    </head>
    <body
     
    <?php
    // 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"]);
       }
    }
     
    function test_input($data) {
       $data = trim($data);
       $data = stripslashes($data);
       $data = htmlspecialchars($data);
       return $data;
    }
    ?>
     
    <h2>PHP Form Validation Example</h2>
    <p><span class="error">* required field.</span></p>
    <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
       <span class="error">* <?php echo $genderErr;?></span>
       <br><br>
       <input type="submit" name="submit" value="Submit"
    </form>
     
    <?php
    echo "<h2>Your Input:</h2>";
    echo $name;
    echo "<br>";
    echo $email;
    echo "<br>";
    echo $website;
    echo "<br>";
    echo $comment;
    echo "<br>";
    echo $gender;
    ?>
     
    </body>
    </html>
    cs












    댓글

Designed by Tistory.