网络编程
位置:首页>> 网络编程>> JavaScript>> AJAX无刷新验证用户名是否存在

AJAX无刷新验证用户名是否存在

作者:84321.Com 来源:84321.Com 发布时间:2007-08-10 10:07:00 

标签:AJAX,无刷新,验证用户名,XMLHTTP

这几天在落伍上转转,发现有朋友不太明白一些网站在会员注册时,当输入用户名后没按“确定”提交数据,系统也能马上检测该用户名是否已经存在。在此我详细的介绍一下原理,代码不多也不复杂,请一定要看完。(注意:该贴为申请落伍贴,在落伍有一年了,到现在都没落伍,悲哀啊):

 GetResult函数说明:
 GetResult(str) 
功能:通过XMLHTTP发送请求,返回结果.
参数:str,字符串,发送条件.
实例:GetResult(document.all.userid.value);
author:www.84321.Com 完善版-有参考网上程序
update:2006-12-26 12:02
下面是reg.htm代码:


<script language="JavaScript">
function GetResult(str)
{
    var exitdos = new ActiveXObject("Microsoft.XMLHTTP");
    //特殊字符:+,%,&,=,?等的传输解决办法.字符串先用escape编码的.
    //Update:2006-12-26 12:22
    exitdos.open("POST","server.asp?userid="+escape(str),false);
    exitdos.send();
    //服务器端处理返回的是经过escape编码的字符串.
    document.all.username.value=unescape(exitdos.responseText)
}
</script>
userid:<input type="text" name="userid" onblur="GetResult(document.all.userid.value)"><br>
username:<input type="text" name="username">



下面是server.asp代码:


<% @Language="JavaScript" %>
<%
function OpenDB(sdbname)
{
    var connstr = "Provider=Microsoft.Jet.OLEDB.4.0; Data Source="+Server.MapPath(sdbname);
    var conn = Server.CreateObject("ADODB.Connection");
    conn.Open(connstr);
    return conn;
}
var sResult = "";
var oConn = OpenDB("data.mdb");
//特殊字符:+,%,&,=,?等的传输解决办法.客户端字符是经过escape编码的
//所以服务器端先要经过unescape解码.
//Update:2004-6-1 12:22
var userid = unescape(Request("userid"));
var sql = "select username from users where userid=’"+userid+"’";
var rs = oConn.Execute(sql);
if(!rs.EOF)
{
    sResult = "Sorry,该用户名已存在"
}
else
{
    //加入容错.2006-12-25 10:15
    sResult = "该用户可以注册"
}
//escape解决了XMLHTTP。中文处理的问题.
Response.Write(escape(sResult));
%>


mdb数据库名:data.mdb
表:users
表结构:id(自动编号) userid(文本) username(文本)


到此,源代码和数据库就完成了,因为用的是:onblur事件,当光标的焦点离开时,input值会马上传到数据库验证,马上试试吧!

0
投稿

猜你喜欢

手机版 网络编程 asp之家 www.aspxhome.com