0

所以我搜索了这个问题并找到了类似的问题,但我不确定如何将他们的解决方案翻译成我的 - 主要是因为我是 PHP 的菜鸟。我在做这个工作。忍受我。感谢您的帮助!

现在,我正在努力做到这一点,这样我的表单将不允许 phpmysql 中的电子邮件列的重复条目。到目前为止,我在那里进入了结构选项卡,并使其独一无二。几乎是中提琴。但是,我希望在提交表单时将错误消息显示在同一页面上,而不是重新加载它并给出消息。另外,我想自定义消息。将其视为与 phpmysql 相关的错误,我不确定是否会使用 PHP 编码或其中的某个地方来执行此操作。

多谢你们。我很感激帮助。

<?php

function checkField($v){
    return (isset($v) && $v === false) ? true: false;
}
function startMysql(){
    $con=mysqli_connect("localhost", "shiftedr_admin", "passwerd", "shiftedr_whosthedeeusers"); 
    // Check connection
    if (mysqli_connect_errno()){
        echo "Failed to connect to MySQL: " . mysqli_connect_error();
    } else {
        return null;
    }
    return $con;
}
//  function closeMySql($connection){
//      mysqli_close($connection);
//  }
function formcheck(){
    $con=mysqli_connect("localhost", "shiftedr_admin", "shithead1", "shiftedr_whosthedeeusers"); 
    // Check connection
    if (mysqli_connect_errno()){
        echo "Failed to connect to MySQL: " . mysqli_connect_error();
    } else { 
        if (isset($_POST['submitted'])){

            $form = null;
            if (empty($_POST['fullname'])){
                $form['fullnameflag'] = false;
            } 
            if (empty($_POST['email'])){
                $form['emailflag'] = false;
            } 
            if (empty($_POST['password'])){
                $form['passwordflag'] = false;
            } 
            if (empty($_POST['pwc'])){
                $form['pwcflag'] = false;
            } 
            if (empty($_POST['userbday'])){
                $form['userbday'] = false;
            }
            if (empty($_POST['gender'])){
                $form['genderflag'] = false;
            } 
            if ($_POST['password'] != $_POST['pwc']){
                $form['fixpasswordconfirm'] = false;
            }


            /*$query = mysql_query ("SELECT * FROM users2  WHERE email = '". Email'" ."'");
          if (mysql_num_rows($query) > 0) 
            { 
 echo 'Email Address is Already In Use.'; 
            }*/

            if (empty($form)) { // all fields correct at this point, do database stuff
                $sql="INSERT INTO Users2 (fullname, Email, Password, userbday, Gender) VALUES ('".$_POST['fullname']."','".$_POST['email']."','".$_POST['password']."','".$_POST['userbday']."','".$_POST['gender']."')";
                if (!mysqli_query($con,$sql)){
                    die('Error: ' . mysqli_error($con));
                }
                echo "1 record added";
            }
        }
        mysqli_close($con);
        return $form;
    }
}

//// /  include("myfunctions.php");
?>
4

1 回答 1

0

我猜你有两个页面 - myform.php 和 process.php 或类似的东西所以尝试这样做

<?php

$error = null; 

if( isset( $_POST['submitted'] ) ) // Same as your check is submitting if
{
    // Below is an example fail
    if( empty( $_POST['fullname'] ) ) $error = 1;

    // So for the email address failing you would put
    if( mysql_num_rows($query) > 0 ) $error = 2;

    if(! $error )
    {
        // all good no errors here so do database stuff....
    }
    else
    {
    header("Location: form.php?error=$error"); // return the error code to previous page
    }
}

?>

如果一个可能是一个空字段,或者全名是空的,两个是使用的电子邮件地址或类似的东西,并且在您的 myform.php 页面上有

 <?php

if( isset( $_GET['error'] ) )
{
    switch ( $_GET['error'] )
    {
        case 1 : echo "One of the fields is empty"; break;

        case 2 : echo "Your email address has already been used"; break;

        default : echo "Unknown error occured";
    }
}

?>
于 2013-09-09T20:42:09.447 回答