Удаленная проверка в jQuery не проверяется - PullRequest
0 голосов
/ 09 февраля 2012

Эта форма вставит в мой MySQL db * 1001 и адрес электронной почты, и пароль.

Во-первых, я пытаюсь проверить электронную почту удаленно, чтобы убедиться, что она не существует, а также что Pswd и Pswd2 равны.

скрипт пишет в БД, но проверка не работает. Я новичок в JQ и Ajax, поэтому любая помощь будет оценена. Спасибо.

ФОРМА:

    <link rel="stylesheet" href="http://code.jquery.com/mobile/1.0.1/jquery.mobile-1.0.1.min.css" />
    <script src="http://code.jquery.com/jquery-1.6.4.min.js"></script>
    <script src="http://code.jquery.com/mobile/1.0.1/jquery.mobile-1.0.1.min.js"></script>
    <script src="jquery.validate.js" type="text/javascript"></script>
    <script src="http://ajax.aspnetcdn.com/ajax/jquery.validate/1.9/additional-methods.min.js"></script>

   ... 
        <div data-role="content">
             <form  id="AddUser" class="ui-body ui-body-a ui-corner-all" data-ajax="true" >
                    <fieldset>
                        <div data-role="fieldcontain">
                            <label for="Email">Email Address:</label>
                            <input id="Email" type="email" />
                        <label for="Pswd">Password:</label>
                            <input id="Pswd" type="password" /> 
                        <label for="Pswd2">Confirm Password:</label>
                            <input id="Pswd2" type="password" />    
                        </div>
                        <button type="submit" id="submit" data-theme="b" name="submit" value="submit-value">Submit</button>
                    </fieldset>
        </form>     
        </div>

...

ниже - js внутри документа:

 <script>
    $(document).ready(function() { 

        var validator = 
        $('#AddUser').validate({ 
            rules: { 
                Pswd: { 
                    required: true, 
                }, 
                Pswd2: { 
                    required: true, 
                    equalTo: "#Pswd" 
                }, 
                Email: { 
                   required: true, 
                   email: true, 
                   remote: "process/ValidateEmail.php" 
                }
            }, 
            messages: { 
                Pswd: { 
                    required: "Provide a password", 
                }, 
                Pswd2: { 
                    required: "Repeat your password", 
                    equalTo: "Enter the same password as above" 
                }, 
                Email: { 
                    required: "Not A Valid Email Address", 
                    remote: "already in use"
                }
             }
        }); // end var validator

            if (validator)
            {
                $("#AddUser").submit(function(){        
                //make Variables
                var emailVar =$('input[id=Email]').val();
                var pswdVar = $('input[id=Pswd]').val();
                var pswdconfirm = $('input[id=Pswd2]').val();
                var querystring = "Email="+emailVar+"&Pswd="+pswdVar;

                $.post("process/AddUser.php",querystring);

            }); //end submit()
            }; // end if validator


    }); //end ready()

    </script>

Файл валидатора (ValidateEmail.php)

<?php 

    $UserEmail = $_POST["Email"];

    include "connection.php";

    $sqlEmail= mysql_query("Select EmailAddress from USERS where EmailAddress='$UserEmail'"); 
    $EmailCheck=mysql_fetch_array($sqlEmail);

    if (mysql_num_rows($EmailCheck) > 0) {
        echo json_encode(true);
    } else {
        echo json_encode(false);
    }

?>

Ответы [ 2 ]

0 голосов
/ 01 октября 2013
            email: { 
            required: true, 
            email: true, 
            remote: {
                url: "check-email.php",
                type: "post",
                data: {
                    email: function() {
                        return $("[name='email']").val();
                    }
                }
            }
          },

и php должен выглядеть так:

$email= $_POST['email'];
include 'connect.php';
$email = trim(mysql_real_escape_string($email));
$query = mysql_query("SELECT COUNT(id) FROM users WHERE email = '$email'") or die(mysql_error());
echo (mysql_result($query, 0) == 1) ? 'false' : 'true';

будьте осторожны, чтобы не повторить просто ложь или истину, оно должно повторяться как это "ложь" или истина

0 голосов
/ 10 февраля 2012

Я вернулся к коду после некоторого исследования и обнаружил, что он изобилует ошибками как в js, так и в проверке php:

<script>
    $(document).ready(function()
  {

    var validator = $("#AddUser").validate({
        rules: {
            Email: {
                required: true,
                email: true,
                remote: "process/ValidateEmail.php"
            },
            Pswd: {
                required: true,
            },
            Pswd2: {
                required: true,
                equalTo: "#Pswd"
            },
        },
        messages: {
            Pswd: {
                required: "Provide a password",
            },
            Pswd2: {
                required: "Repeat your password",
                equalTo: "Password Mismatch"
            },
            Email: {
                required: "Invalid Email",
                remote: jQuery.format("{0} is already used")
            }
        },
        // the errorPlacement has to take the table layout into account
        errorPlacement: function(error, element) {

                error.appendTo(element.parent().next());
        },
        // specifying a submitHandler prevents the default submit, good for the demo
        submitHandler: function() {         

            //make Variables
            var emailVar =$('input[id=Email]').val();
            var pswdVar = $('input[id=Pswd]').val();
            var pswdconfirm = $('input[id=Pswd2]').val();
            var querystring = "Email="+emailVar+"&Pswd="+pswdVar;

            $.post("process/AddUser.php",querystring);

            $('#AddUser').clearForm();
        return false;

        },
        // set this class to error-labels to indicate valid fields
        success: 

            function(label) {
            label.html("&nbsp;").addClass("checked");

        }
        });
    }); 
</script>
...