如何檢查電子郵件是否已被使用?我發現了一個腳本,但它只顯示「正在檢查」,如果電子郵件存在,我無法得到確切的結果。下面你有代碼:提交前檢查郵件無法正常工作
<span id="usernamestatus"></span>
<input type="text" onblur="checkusername()" id="sign_up_email_input_first" name="email_sign_up" placeholder="E-Mail">
function checkusername() {
var status = document.getElementById("usernamestatus");
var u = document.getElementById("sign_up_email_input_first").value;
if (u !="") {
status.innerHTML = 'checking...';
var hr = new XMLHttpRequest();
hr.open("POST", "name_check.php", true);
hr.setRequestHeader("Content-type", "application/x-www-form-urlendcoded");
hr.onreadystatechange = function(){
if (hr.readyState == 4 && hr.status ==200) {
status.innerHTML = hr.responseText;
}
}
var v = "name2check="+u;
hr.send(v);
}
}
name_check.php
if(isset($_POST['sign_up_email_input_first']) && $_POST['sign_up_email_input_first'] != "") {
$username = $_POST['sign_up_email_input_first'];
$sql_name_check = mysql_query("SELECT id FROM users WHERE email = '$username' LIMIT 1");
$uname_check= mysql_num_rows($sql_name_check);
if(strlen($username)<4){
echo "You have invalid e mial adress";
exit();
}
if($uname_check <1){
echo "<strong>". $username. "</strong> Is OK";
exit();
}else{
echo "<strong>" .$username. "</strong> is taken!";
exit();
}
}
如何*特別是*此代碼不按預期工作?當你在一個調試器中執行時,觀察到的行爲究竟與預期的行爲有什麼不同?發生這種情況時的運行時間值是什麼?還要注意,這段代碼是*開放*到** SQL注入**,所以你可以從字面上執行任何*在你的數據庫中。你也沒有檢查錯誤,你應該在執行數據庫查詢後總是這樣做。數據庫*可能會試圖告訴你問題是什麼。 – David