tags:

views:

53

answers:

1

Hello all,

I follow the demo http://jquery.bassistance.de/validate/demo/marketo/ and met some problems to achieve the same remote validation function.

Here is HTML I used.

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/2000/REC-xhtml1-200000126/DTD/xhtml1-transitional.dtd"&gt;
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
<head>
<title>Subscription Signup | Marketo</title>
<!--http://jquery.bassistance.de/validate/demo/marketo/--&gt;
<link rel="stylesheet" type="text/css" media="screen" href="css/stylesheet.css" />
<script type="text/javascript" src="js/jquery/jquery-1.4.2.js"   ></script>
<script type="text/javascript" src="js/jquery/jquery.validate.js"></script>
<script type="text/javascript">

$(document).ready(function(){

$("#profileForm").validate({
  invalidHandler: function(e, validator) {
   var errors = validator.numberOfInvalids();
   if (errors) {
    var message = errors == 1
     ? 'You missed 1 field. It has been highlighted below'
     : 'You missed ' + errors + ' fields.  They have been highlighted below';
    $("div.error span").html(message);
    $("div.error").show();
   } else {
    $("div.error").hide();
   }
  },
  onkeyup: false,
  submitHandler: function() {
   $("div.error").hide();
   alert("submit! use link below to go to the other step");
  },
  messages: {
   password2: {
    required: " ",
    equalTo: "Please enter the same password as above" 
   },
   email: {
    required: " ",
    email: "Please enter a valid email address, example: [email protected]",
    remote: jQuery.validator.format("{0} is already taken, please enter a different address.") 
   }
  },
  debug:true
 });

});

</script>
</head>
<body>
<div>
 <form id="profileForm" action="" method="POST" >
  <div class="error" style="display:none;"> 
   <img src="images/warning.gif" alt="Warning!" width="24" height="24" style="float:left; margin: -5px 10px 0px 0px; " /> 
   <span></span>.<br clear="all"/>
  </div>
  <table cellpadding="0" cellspacing="0" border="0">
   <tr>
    <td colspan="2"><h2 style="border-bottom: 1px solid #CCCCCC;">Login Information</h2></td>
   </tr>
   <tr>
    <td class="label"><label for="email">Email:</label></td>
    <td class="field"><input id="email" class="required email" remote="emails.php" maxlength="40" name="email" size="20" type="text" tabindex="11" value="" /></td>
   </tr>
   <tr>
    <td class="label"><label for="password1">Password:</label></td>
    <td class="field"><input id="password1" class="required password" maxlength="40" name="password1" size="20" type="password" tabindex="12" value="" /></td>
   </tr>
   <tr>
    <td class="label"><label for="password2">Retype Password:</label></td>
    <td class="field"><input id="password2" class="required" equalTo="#password1" maxlength="40" name="password2"  size="20" type="password" tabindex="13" value="" />
     <div class="formError"></div></td>
   </tr>
   <tr>
    <td></td>
    <td><div class="buttonSubmit">
      <input class="formButton" type="submit" value="Next" style="width: 140px" tabindex="14" />
     </div></td>
   </tr>
  </table>
 </form>
</div>
</body>
</html>

Here is the PHP script:

<?php

$request = trim(strtolower($_REQUEST['value']));
$emails = array('[email protected]', '[email protected]', '[email protected]', '[email protected]', '[email protected]', '[email protected]');
$valid = 'true';
foreach($emails as $email) {
 if( strtolower($email) == $request )
  $valid = 'false';
}
echo $valid;
?>

When I enter [email protected] and then click TAB, I found the following error messages through filebug:

param: email [email protected] response:
Notice: Undefined variable: request in C:\wamp\www\ajax_login_validation\emails.php on line 4

Notice: Undefined index: value in C:\wamp\www\ajax_login_validation\emails.php on line 5
true

It seems that it complains the $_REQUEST['value']

How can I fix this problem.

Many thanks

+4  A: 

It should be $_REQUEST['email'] instead of $_REQUEST['value']

dejavu
A note on why this is the case: `$_REQUEST['value']` looks for a form input element with a `name` attribute of `value`. This doesn't exist (which is why you are getting those notices). Since your form input element has a `name` attribute of `email` you can either change your PHP script to use `email` (as suggested here), or change your form input element to be named `value`.
Blair McMillan