2016-06-01 78 views
1

如何檢查電子郵件是否已被使用?我發現了一個腳本,但它只顯示「正在檢查」,如果電子郵件存在,我無法得到確切的結果。下面你有代碼:提交前檢查郵件無法正常工作

<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(); 
     } 
    }               
+4

如何*特別是*此代碼不按預期工作?當你在一個調試器中執行時,觀察到的行爲究竟與預期的行爲有什麼不同?發生這種情況時的運行時間值是什麼?還要注意,這段代碼是*開放*到** SQL注入**,所以你可以從字面上執行任何*在你的數據庫中。你也沒有檢查錯誤,你應該在執行數據庫查詢後總是這樣做。數據庫*可能會試圖告訴你問題是什麼。 – David

回答

1

在你的PHP文件,替換

$_POST['sign_up_email_input_first'] 

有:

$_POST['email_sign_up'] 

你基本上GR AB值與名稱,而不是ID的

+0

這是一個Ajax請求,而不是一個表單。 – Khaleel

0

您還沒有提交表單。您只需將數據發送至name_check.php,並將字段名稱「u」作爲xmlhttprequest

嘗試代替$_POST['sign_up_email_input_first']上你的PHP文件中使用$_POST['u']