如何验证一个变量在PHP中的两个变量之一

时间:2018-10-10 11:14:34

标签: php forms validation

我现在有两个变量mobile和email,我想同时验证这两个变量,但是如果用户不希望用ex登记,那么我希望用户将其中一个字段留空,如果用户不想用他的电子邮件注册,那么他可以转到手机号码进行注册,反之亦然,这是我的验证码

<?php

$emailError    = "";
$fullnameError = "";
$usernameError = "";
$passwordError = "";
$mobileerror = "";
$errors        = 0;

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

    $email    = strip_tags($_POST['email']);
    $fullname = strip_tags($_POST['fullname']);
    $username = strip_tags($_POST['username']);
    $password = strip_tags($_POST['password']);
    $mobile = strip_tags($_POST['mobile']);



    $fullname_valid = $email_valid = $mobile_valid = $username_valid = $password_valid = false;



    if (!empty($fullname)) {

        if (strlen($fullname) > 2 && strlen($fullname) <= 30) {
            if (!preg_match('/[^a-zA-Z\s]/', $fullname)) {
                $fullname_valid = true;

                # code...
            } else {
                $fullnameError = "fullname can contain only alphabets <br>";
                $errors++;
            }
        } else {
            $fullnameError = "fullname must be 2 to 30 char long <br>";
            $errors++;
        }
    } else {
        $fullnameError = "fullname can not be blank <br>";
        $errors++;
    }



        if (filter_var($email, FILTER_VALIDATE_EMAIL)) {

            $query2 = "SELECT email FROM users WHERE email = '$email'";
            $fire2 = mysqli_query($con, $query2) or die("can not fire  query" . mysqli_error($con));
            if (mysqli_num_rows($fire2) > 0) {
                $emailError = $email . "is already taken please try another one<br> ";
            } else {
                $email_valid = true;
            }
            # code...
        } else {
            $emailError = $email . "is an invalid email address <br> ";
            $errors++;
        }
        # code...

   if ($mobile) {
      $query4 = "SELECT mobile FROM users WHERE mobile = '$mobile'";
            $fire4 = mysqli_query($con, $query4) or die("can not fire  query" . mysqli_error($con));
            if (mysqli_num_rows($fire4) > 0) {
                $mobileerror =  "is already taken please try another one<br> ";
            } else {
                $mobile_valid = true;
            }
   }

    if (!empty($username)) {

        if (strlen($username) > 4 && strlen($username) <= 15) {
            if (!preg_match('/[^a-zA-Z\d_.]/', $username)) {


                $query = "SELECT username FROM users WHERE username = '$username'";
                $fire = mysqli_query($con, $query) or die("can not fire  query" . mysqli_error($con));


                if (mysqli_num_rows($fire) > 0) {
                    $usernameError = '<p style="color:#cc0000;">username already taken</p>';
                    $errors++;
                } else {
                    $username_valid = true;
                }

            } else {
                $usernameError = "username can contain only alphabets <br>";
                $errors++;
            }
        } else {
            $usernameError = "username must be 4 to 15 char long <br>";
            $errors++;
        }
    } else {
        $usernameError = "username can not be blank <br>";
        $errors++;
    }

    if (!empty($password)) {
        if (strlen($password) >= 5 && strlen($password) <= 15) {
            $password_valid = true;
            $password       = md5($password);

            # code...
        } else {
            $passwordError = $password . "password must be between 5 to 15 character long<br>";
            $errors++;
        }
        # code...
    } else {
        $passwordError = "password can not be blank <br>";
        $errors++;
    }

    //if there's no errors insert into database
    if ($errors <= 0) {
        if ($fullname_valid && ($email_valid || $mobile_valid )&& $password_valid && $username_valid) {
            $query = "INSERT INTO users(fullname,email,username,password,avatar_path) VALUES('$fullname','$email','$username','$password','avatar.jpg')";
            $fire = mysqli_query($con, $query) or die("can not insert data into database" . mysqli_error($con));
            if ($fire) {


                header("Location: dashboard.php");
            }
        }

    }
}
?>

现在,当我使用电子邮件并留空的手机时,代码可以正常工作,但是当我使用电子邮件并留空的手机时,会出现错误的解决方法

2 个答案:

答案 0 :(得分:-1)

再使用一个标志 $isValid_email_mobile = FALSE;

当控制流进入if (filter_var($email, FILTER_VALIDATE_EMAIL))时,在SUCCESS上只需设置$ isValid_email_mobile = TRUE;如果控件在SUCCESS上再次进入条件if ($mobile),将其设置为$isValid_email_mobile = TRUE;

,将是相同的

当$ isValid_email_mobile = FALSE时;变为TRUE,那么您知道该字段/变量已满足您的要求,并已准备就绪,可以进行数据库插入

然后

在您尝试插入的上一个IF条件中,只需将IF条件更改为以下

IF ($fullname_valid &&  $isValid_email_mobile && $password_valid && $username_valid)

每当您使用标志逻辑时,还要做一件事,始终在使用标志之前将其设置为默认值。

答案 1 :(得分:-1)

  

现在,当我使用电子邮件并留空的手机时,代码可以正常工作,但是当我使用电子邮件并留空的手机时,会发生错误

您有:

if (!empty($fullname)) {}
if (filter_var($email, FILTER_VALIDATE_EMAIL)) {}
if ($mobile) {}
if (!empty($username)) {}
if (!empty($password)) {}

要消除该错误,请尝试添加

if (!empty($mobile)) {

此外,我建议多包装一些语句。您只需一个失败即可停止输入。您可以执行以下操作:

$mobileOrEmail = false;
if (!empty($fullname) && !empty($username) && !empty($password) {
  //check fullname, username and password
  if (!empty($mobile) {
    //check mobile, if it passes
    $mobileOrEmail = true;
  }
  if (filter_var($email, FILTER_VALIDATE_EMAIL)) {
    //check email, if it passes
    $mobileOrEmail = true;
  }
  if (!$mobileOrEmail) $errors++;
} else {
  //missing input values
  $errors++;
}

我个人会为每个输入字段创建一个函数。

function checkUsername($username){
  //check username
  return true;
}
function checkEmail($email) {
  //check email
  return true;
}
....

然后您可以运行

if (checkUsername($username) && checkPassword($password)
    && checkFullname($fullname) && (checkEmail($email) || checkEmail($email)) {
    //user input correct
 } else {
   //user input failed
 }

只是给它更多的结构