php+ajax注冊實時驗證功能

字號:


    ajax的實時驗證技術(shù)已經(jīng)很成熟了,在一些規(guī)范的網(wǎng)站上,如果有注冊驗證的模板,必定會涉及到ajax的無刷新驗證,這在用戶注冊的體驗中是很棒的,對比一個不能及時和后臺無刷新對接的驗證模式,要重新返回來刷新,這對于用戶來說,體驗上是很不友好的。
    ajax的模式幾乎是所有站點應(yīng)用的需求,ajax作為前端無刷新驗證,可以和所有后臺語言進(jìn)行組合使用,比如asp+ajax,php+ajax,.net+ajax等等組合,這里主要講解的是php+ajax的注冊驗證。
    下面的驗證是一個完整的實例,我們在網(wǎng)站上面注冊時,在輸入用戶名時,首先要進(jìn)行無刷新驗證,要驗證一下后臺數(shù)據(jù)庫里面是否存在同名的數(shù)據(jù),如果存在,則無刷新顯示用戶名已被占用的提示,這里一共涉及到四個文件。
    ajax.js:ajax技術(shù)的核心文件了,主要是驗證提示的時時顯示,這個文件通常不需要進(jìn)行修改,只需要進(jìn)行前端調(diào)用即可。
    var xmlHttp
    function showHint(str)
    {
    if (str.length==0)
     { 
     document.getElementById("txtHint").innerHTML=""
     return
     }
    xmlHttp=GetXmlHttpObject()
    if (xmlHttp==null)
     {
     alert ("Browser does not support HTTP Request")
     return
     } 
    xmlHttp.onreadystatechange=stateChanged 
    var geturl="conn.php?q="+str
    //sid是增加一個隨機數(shù) 防止頁面啟用緩存技術(shù)·
    geturl=geturl+"&sid="+Math.random()
    geturl=encodeURI(geturl);
    geturl=encodeURI(geturl); 
    xmlHttp.open("GET",geturl,true)
    xmlHttp.send(null)
    } 
    function stateChanged() 
    { 
    if (xmlHttp.readyState==4 || xmlHttp.readyState=="complete")
     { 
     document.getElementById("txtHint").innerHTML=xmlHttp.responseText 
     } 
    }
    function GetXmlHttpObject()
    {
    var xmlHttp=null;
    try
     {
     // Firefox, Opera 8.0+, Safari
     xmlHttp=new XMLHttpRequest();
     }
    catch (e)
     {
     // Internet Explorer
     try
     {
     xmlHttp=new ActiveXObject("Msxml2.XMLHTTP");
     }
     catch (e)
     {
     xmlHttp=new ActiveXObject("Microsoft.XMLHTTP");
     }
     }
    return xmlHttp;
    }
    conn.php:這是網(wǎng)站的配置文件,要配置好自己本地的mysql用戶名和密碼,需要配置PHP與數(shù)據(jù)庫的連接,可以參考PHP+MYSQL數(shù)據(jù)庫連接的文章,另外要處理接受過來的數(shù)據(jù)進(jìn)行時實顯示,如果有多項要驗證的文件,在這里進(jìn)行多項接受和驗證即可。
    <?php
    $q=$_GET["q"];
    $q = urldecode($q);
    if (strlen($q) > 0)
    {
     $conn = @mysql_connect("localhost","root","1010") or die ("MySql連接錯誤");
     mysql_select_db("xin",$conn);
     mysql_query("set names 'utf8'");
     $sql = "SELECT username FROM message WHERE username = '$q'";
     $query = mysql_query($sql);
     @$row = mysql_fetch_array($query);
     if(!empty($row['username']))
     {
     $response = "<font color=red>已經(jīng)被注冊!</font>";
     }else
     {
     $response = "<font color=blue>恭喜!可以注冊!</font>";
     }
     echo $response;
    }
    ?>
    index.html:這就是前端文件了,這個文件相對來說要更簡單一些,調(diào)用了ajax.js的處理文件,將要提交無刷新驗證的文件提交到conn.php和后臺進(jìn)行連接。
    <html>
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
    <script src="ajax.js"></script> 
    </head>
    <body bgcolor="#999999">
    <center>
    <form> 
    <table>
     <tr>
     <td>用戶名:</td>
     <td><input type="text" id="txt1" onKeyUp="showHint(this.value)"></td>
     </tr>
     <tr>
     <td colspan="2"><span id="txtHint"></span></td>
     </tr>
    </table>
    </form>
    </center>
    </body>
    </html>
    庫.txt:這個就是SQL的數(shù)據(jù)庫文件了,將這個文件導(dǎo)入到mysql數(shù)據(jù)庫中即可。
    DROP DATABASE IF EXISTS `xin`;
    CREATE DATABASE `xin` /*!40100 DEFAULT CHARACTER SET utf8 */;
    USE `xin`;
    CREATE TABLE `message` (
     `id` int(11) NOT NULL auto_increment,
     `username` varchar(20) default NULL,
     PRIMARY KEY (`id`)
    ) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8;
    將這幾個文件保存在可以運行PHP文件的根目錄即可,測試網(wǎng)址為 localhost/index.html,下面是打包下載的整套文件,試著修改為自己需求的注冊模塊,比如加上密碼,姓名之類的。
    以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助