开发者

PHP empty() error message

开发者 https://www.devze.com 2023-02-24 06:57 出处:网络
I have just started learning and have put together the form below. The confusion I have is when I use empty to validate if the user selected or entered any information, the code generates the error be

I have just started learning and have put together the form below. The confusion I have is when I use empty to validate if the user selected or entered any information, the code generates the error below.

I noticed if I have the following lines of code

if(empty($gender)) {
        $errormessage[2] = "Please select your gender";
    } 

as

if(empty($_POST["gender"])) {
        $errormessage[2] = "Please select your gender";
    }

and

if(empty($gender)) {
        $errormessage[2] = "Please select your gender";
    }

as

if(empty($_POST["gender"])) {
        $errormessage[2] = "Please select your gender";
    }

I do not see the error message. I take it that error message is being generated because of the lines of code $_POST for the gender and media form elements which are radio buttons and checkboxes respectively. However if I want to initialize all the variables at the top, what is the best way to do so?

/* <?p开发者_JAVA技巧hp

if(isset($_POST["submit"])) {

    $fname = $_POST["fname"];
    $lname = $_POST["lname"];
    $gender = $_POST["gender"];
    $age = $_POST["age"];
    $address = $_POST["address"];
    $media = $_POST['media'];

    $errormessage =  array();

    if(empty($fname)) {
        $errormessage[0] = "Please enter your first name";
    }

    if(empty($lname)) {
        $errormessage[1] = "Please enter your last name";
    }

    if(empty($gender)) {
        $errormessage[2] = "Please select your gender";
    }

    if(empty($age)) {
        $errormessage[3] = "Please select your age";
    }

    if(empty($address)) {
        $errormessage[4] = "Please enter your address";
    }

    if(empty($media)) {
        $errormessage = "Please select the type of media";

    }

}
?>
<html>
<head>
    <title>Sample Registration</title>
</head>
<body>
    <h2>Sample registration</h4>
        <form name="registration" method="post" action="registration.php">
            <div>
                First Name: <br />
                <input type="text" name="fname" value="">
            </div>

            <div>
                Last Name: <br />
                <input type="text" name="lname" value="">
            </div>

            <div>
                Gender: <br />
                male<input type="radio" name="gender" value="male">
                female<input type="radio" name="gender" value="female">
            </div>

            <div>
                Age: <br />
                <select name="age">
                    <option value="">Please select your age</option>
                    <option value="18-25">18-25</option>
                    <option value="26-33">26-33</option>
                </select>
            </div>

            <div>
                Address: <br />
                <textarea name="address" cols="10" rows="10"></textarea>
            </div>

            <div>
                Sign-me up: <br />
                <input type="checkbox" name="media['newsletter']" value="newsletter"> newsletter
                <input type="checkbox" name="media['specials']" value="specials"> specials
                <input type="checkbox" name="media['events']" value="events"> events

            <div>
                <input type="submit" name="submit" value="submit">
            </div>
        </form>
</body>
</html>

*/

/* Error Message */

! ) Notice: Undefined index: gender in C:\Program Files\EasyPHP-5.3.5.0\www\registration.php on line 7
Call Stack
#   Time    Memory  Function    Location
1   0.0004  341792  {main}( )   ..\registration.php:0
Dump $_SERVER

$_SERVER['REMOTE_ADDR'] =



string '127.0.0.1' (length=9)

$_SERVER['REQUEST_METHOD'] =



string 'POST' (length=4)

$_SERVER['REQUEST_URI'] =



string '/registration.php' (length=17)

Variables in local scope (#1)

$address =

    Undefined

$age =

    Undefined

$errormessage =

    Undefined

$errormsg =

    Undefined

$fname =



string '' (length=0)

$gender =

    Undefined

$lname =



string '' (length=0)

$media =

    Undefined

( ! ) Notice: Undefined index: media in C:\Program Files\EasyPHP-5.3.5.0\www\registration.php on line 10
Call Stack
#   Time    Memory  Function    Location
1   0.0004  341792  {main}( )   ..\registration.php:0
Variables in local scope (#1)

$address =



string '' (length=0)

$age =



string '' (length=0)

$errormessage =

    Undefined

$errormsg =

    Undefined

$fname =



string '' (length=0)

$gender =



null

$lname =



string '' (length=0)

$media =

    Undefined


You'll want to check whether those $_POST['gender'] and $_POST['media'] variables were actually set in the HTTP POST request before you go accessing them; a better solution to initialize each $_POST var might be something like this:

$fname = isset( $_POST['fname'] ) ? $_POST['fname'] : '';

The above ternary assignment is equivalent to running the following logical expression for every single $_POST variable in which you're interested:

if( isset( $_POST['fname'] ) ) {
    $fname = $_POST['fname'];
} else {
    $fname = '';
}

If you implement either of these, you won't get a notice if you run empty() on $gender; furthermore, if $_POST['gender'] wasn't set, empty() will still behave the way you expect. It adds a little verbosity, but to rewrite your example you might try:

if( isset( $_POST["submit"] ) ) {

    $fname = isset( $_POST['fname'] ) ? $_POST["fname"] : '';
    $lname = isset( $_POST['lname'] ) ? $_POST["lname"] : '';
    $gender = isset( $_POST['gender'] ) ? $_POST["gender"] : '';
    $age = isset( $_POST['age'] ) ? $_POST["age"] : '';
    $address = isset( $_POST['address'] ) ? $_POST["address"] : '';
    $media = isset( $_POST['media'] ) ? $_POST['media'] : '';

    $errormessage =  array();
    if( empty( $fname ) )
        $errormessage[] = "Please enter your first name";
    if( empty( $lname ) )
        $errormessage[] = "Please enter your last name";
    if( empty( $gender ) )
        $errormessage[] = "Please select your gender";
    if( empty( $age ) )
        $errormessage[] = "Please select your age";
    if( empty( $address ) )
        $errormessage[] = "Please enter your address";
    if( empty( $media ) )
        $errormessage[] = "Please select the type of media";
}

Of course, you'd want to clean your data if you're going to use it in a SQL context, but that should at least get you around the error you're facing.

If you had a lot of these variables--or were repeating this task often--you might consider rolling it up into a function!


Try using !isset() instead of empty().

As a side-note, the way you're assigning your variables will create warning notices if that $_POST value doesn't exist. If you'd like to remove those notices, use @Ryan's solution.

0

精彩评论

暂无评论...
验证码 换一张
取 消