[英]Email availability check returning available for every email
表單提交的HTML代碼:
<div class="control-group">
<label class="control-label" for="input01">Email</label>
<div class="controls">
<input type="text" class="input-xlarge" id="email" name="email"
rel="popover" data-content="What’s your email address?"
data-original-title="Email">
<span class="check" style="color:red;" ></span>
</div>
</div>
jQuery代碼將電子郵件發布到PHP腳本中:
$(function () {
$('#email').keyup(function () {
var email = $(this).val();
if (email != '') {
//$('.check').show();
$('error').fadeIn(400).html('<img src="/img/ajax-loading.gif" />');
var dataString = 'email=' + email;
$.ajax({
type: "POST",
url: "pages/check_email.php",
data: dataString,
cache: false,
success: function (result) {
if (result == '') {
$('.check').html(email + ' Avaliable');
$('#create').attr('disabled', '');
$('#create').attr('value', 'Active');
$("#email").removeClass("red");
$("#email").addClass("white");
} else {
$('.check').html(email + ' ' + result);
$('#create').attr('disabled', 'disabled');
$('#create').attr('value', 'Deactive');
$("#email").removeClass("white");
$("#email").addClass("red");
}
}
});
} else {
$('.check').html('');
$('#submit').attr('disabled', 'disabled');
$('#submit').attr('value', 'Deactive');
}
});
});
PHP代碼,用於檢查電子郵件的可用性並在找到/未找到值時返回1或0:
include_once "../base.php";
$stmt = $db->prepare("SELECT * FROM `Consultants` WHERE email =':email'");
$stmt->bindParam(":email", $_POST['email']);
$stmt->execute();
$num_rows = $stmt->fetchColumn();
$HTML='';
if($num_rows > 0){
$HTML='is already used';
}else{
$HTML='';
}
echo $HTML;
$stmt = null;
對於輸入的每個電子郵件,它將返回“可用”。 我的數據庫中有幾封電子郵件正在使用。 我在控制台中也沒有收到任何錯誤。
您從“ Consultants
表中選擇所有字段,因此第一列的值可能大於0。
此外,您准備好的語句不應在綁定參數:email
周圍使用引號。
修理:
$stmt = $db->prepare("SELECT COUNT(*) FROM `Consultants` WHERE email =:email");
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.