PHP+AJAX实现无刷新注册(带用户名实时检测)


Posted in PHP onJanuary 02, 2007

很多时候,我们在网上注册个人信息,在提交完页面后,总得等待页面刷新来告诉我们注册是否成功,遇到网络差的时候,如果注册了一大串的东西,在经过漫长的等待页面刷新后,得到的确是“您的用户名已被使用”或XXXXXXX不合法,我想大家的心情一定特别不爽,今天就介绍个AJAX实现页面不刷新注册+实时检测用户信息的简单注册程序,希望对大家有所帮助。好的,先看注册界面代码:

  <table width="831" border="0" align="center" cellpadding="0" cellspacing="0">
  <tr style="display:none">
    <td height="35" align="center" id="result"> </td>
  </tr>
</table>
<table width="100%" height="256" border="0" align="center" cellpadding="1" cellspacing="1">
      <tr>
        <td width="150" align="left" bgcolor="#FFFFFF">  · 用户名称:          </td>
        <td width="310" align="center" bgcolor="#FFFFFF"> 
          <input name="username" type="text" class="inputtext" id="username" onChange="usercheck('check')" onBlur="usercheck('check')">
        <font color="#FF6633">*</font></td>
        <td align="left" bgcolor="#FFFFFF" id="check"> 4-16个字符,英文小写、汉字、数字、最好不要全部是数字。</td>
      </tr>
      <tr>
        <td width="150" align="left" bgcolor="#FFFFFF">   · 用户密码:</td>
        <td width="310" align="center" bgcolor="#FFFFFF"> 
          <input name="userpwd" type="password" class="inputtext" id="userpwd" onChange="pwdcheck('pwd')" onBlur="pwdcheck('pwd')"
          <font color="#FF6633">*</font>        </td>
        <td align="left" bgcolor="#FFFFFF" id="pwd"> 密码字母有大小写之分。6-16位(包括6、16),限用英文、数字。</td>
      </tr>
   <tr>
        <td width="150" align="left" bgcolor="#FFFFFF">  · 重复密码:</td>
        <td width="310" align="center" bgcolor="#FFFFFF">  
          <input name="reuserpwd" type="password" class="inputtext" id="reuserpwd" onChange="pwdrecheck('repwd')" onBlur="pwdrecheck('repwd')"> 
           <font color="#FF6633">*</font>        </td>
        <td align="left" bgcolor="#FFFFFF" id="repwd"> 请再次输入登录密码。</td>
   </tr>
    </table>

如图:

PHP+AJAX实现无刷新注册(带用户名实时检测)

 

红色部分就是一会要调用的js函数了,当我们选定一个文本框后就会开始调用,现在我们看上面那个页面包含的ajaxreg.js文件的代码,里面就是包含了ajax框架和一些判断函数。

var http_request=false;
  function send_request(url){//初始化,指定处理函数,发送请求的函数
    http_request=false;
 //开始初始化XMLHttpRequest对象
 if(window.XMLHttpRequest){//Mozilla浏览器
  http_request=new XMLHttpRequest();
  if(http_request.overrideMimeType){//设置MIME类别
    http_request.overrideMimeType("text/xml");
  }
 }
 else if(window.ActiveXObject){//IE浏览器
  try{
   http_request=new ActiveXObject("Msxml2.XMLHttp");
  }catch(e){
   try{
   http_request=new ActiveXobject("Microsoft.XMLHttp");
   }catch(e){}
  }
    }
 if(!http_request){//异常,创建对象实例失败
  window.alert("创建XMLHttp对象失败!");
  return false;
 }
 http_request.onreadystatechange=processrequest;
 //确定发送请求方式,URL,及是否同步执行下段代码
    http_request.open("GET",url,true);
 http_request.send(null);
  }
  //处理返回信息的函数
  function processrequest(){
   if(http_request.readyState==4){//判断对象状态
     if(http_request.status==200){//信息已成功返回,开始处理信息
   document.getElementById(reobj).innerHTML=http_request.responseText;
  }
  else{//页面不正常
   alert("您所请求的页面不正常!");
  }
   }
  }
  function usercheck(obj){
   var f=document.reg;
   var username=f.username.value;
   if(username==""){
   document.getElementById(obj).innerHTML=" <font color=red>用户名不能为空!</font>";
 f.username.focus();
 return false;
   }
   else{
   document.getElementById(obj).innerHTML="正在读取数据...";
   send_request('checkuserreg.php?username='+username);
   reobj=obj;
   }
  }
  function pwdcheck(obj){
    var f=document.reg;
 var pwd=f.userpwd.value;
 if(pwd==""){
   document.getElementById(obj).innerHTML=" <font color=red>用户密码不能为空!</font>";
   f.userpwd.focus();
   return false;
 }
 else if(f.userpwd.value.length<6){
   document.getElementById(obj).innerHTML=" <font color=red>密码长度不能小于6位!</font>";
   f.userpwd.focus();
   return false;
 }
 else{
   document.getElementById(obj).innerHTML=" <font color=red>密码符合要求!</font>";
 }
  }
  function pwdrecheck(obj){
    var f=document.reg;
 var repwd=f.reuserpwd.value;
 if (repwd==""){
   document.getElementById(obj).innerHTML=" <font color=red>请再输入一次密码!</font>";
   f.reuserpwd.focus();
   return false;
 }
 else if(f.userpwd.value!=f.reuserpwd.value){
   document.getElementById(obj).innerHTML=" <font color=red>两次输入的密码不一致!</font>";
   f.reuserpwd.focus();
   return false;
 }
 else{
   document.getElementById(obj).innerHTML=" <font color=red>密码输入正确!</font>";
 }
}

   不难看出,数据是通过异步传输到checkuserreg.php接着回送回信息显示出来来达到实时检测用户名的目的,至于密码,只作了长度的实时判断,有兴趣的朋友可以扩充功能。来看下checkuserreg.php到底都做了什么:

<?php
  header('Content-Type:text/html;charset=GB2312');//避免输出乱码
  include('inc/config.inc.php');//包含数据库基本配置信息
  include('inc/dbclass.php');//包含数据库操作类
  $username=trim($_GET['username']);//获取注册名
  //-----------------------------------------------------------------------------------
  $db=new db;//从数据库操作类生成实例
  $db->mysql($dbhost,$dbuser,$dbpassword,$dbname);//调用连接参数函数
  $db->createcon();//调用创建连接函数
  //-----------------------------------------------------------------------------------
  $querysql="select username from cr_userinfo where username='$username'";//查询会员名
  $result=$db->query($querysql);
  $rows=$db->loop_query($result);
  //若会员名已注册
  //-----------------------------------------------------------------------------------
  if($rows){
   echo" <font color=red>此会员名已被注册,请更换会员名!</font>";
  }
  //会员名未注册则显示 

  //----------------------------------------------------------------------------
  else{
   echo" <font color=red>此会员名可以注册!</font>";
  }
  if($action==reg){
  $addsql="insert into cr_userinfo
          values(0,'$username','$userpwd','$time',50,1,'$userquestion','$useranswer')";

  $db->query($addsql);
  echo"<img src=images/pass.gif> <font color=red>恭喜您,注册成功!请点击<a href=login.php>这里</a>登陆!</font>";
  }
  $db->close();//关闭数据库连接
?>

   注释写的还算详细,大家应该都能看懂,再看信息合法后我们提交注册信息实现无刷新注册的PHP代码,senduserinfo.php:

<?php
  header('Content-Type:text/html;charset=GB2312');//避免输出乱码
  include('inc/config.inc.php');//包含数据库基本配置信息
  include('inc/dbclass.php');//包含数据库操作类
  $username=trim($_GET['username']);//获取注册名
  $userpwd=md5(trim($_GET['userpwd']));//获取注册密码
  $time=date("Y-m-d");

  //-----------------------------------------------------------------------------------
  $db=new db;//从数据库操作类生成实例
  $db->mysql($dbhost,$dbuser,$dbpassword,$dbname);//调用连接参数函数
  $db->createcon();//调用创建连接函数
  //-----------------------------------------------------------------------------------
  //开始插入数据
  //-----------------------------------------------------------------------------------
  $addsql="insert into cr_userinfo values(0,'$username','$userpwd','$time',50,1,'$userquestion','$useranswer')";
  $db->query($addsql);
  echo"<img src=images/pass.gif> <font color=red>恭喜您,注册成功!请点击<a href=login.php>这里</a>登录!</font>";

  $db->close();//关闭数据库连接
?>

OK!!大功告成,来看看效果图:

1.

PHP+AJAX实现无刷新注册(带用户名实时检测)

 

2.

PHP+AJAX实现无刷新注册(带用户名实时检测)

 

3.

PHP+AJAX实现无刷新注册(带用户名实时检测)

 

4.

PHP+AJAX实现无刷新注册(带用户名实时检测)

 

5.

PHP+AJAX实现无刷新注册(带用户名实时检测)

 

怎么样?还不错吧,贴了这么多累死了,希望大家喜欢~~~~

PHP 相关文章推荐
缓存技术详谈―php
Dec 14 PHP
解析php时间戳与日期的转换
Jun 06 PHP
php设计模式之单例、多例设计模式的应用分析
Jun 30 PHP
php获得用户ip地址的比较不错的方法
Feb 08 PHP
PHP中Session引起的脚本阻塞问题解决办法
Apr 08 PHP
Yii框架调试心得--在页面输出执行sql语句
Dec 25 PHP
php限制上传文件类型并保存上传文件的方法
Mar 13 PHP
Laravel5.5 手动分页和自定义分页样式的简单实现
Oct 15 PHP
php的RSA加密解密算法原理与用法分析
Jan 23 PHP
php回调函数处理数组操作示例
Apr 13 PHP
PHP dirname功能及原理实例解析
Oct 28 PHP
PHP isset empty函数相关面试题及解析
Dec 11 PHP
新手学PHP之数据库操作详解及乱码解决!
Jan 02 #PHP
默默小谈PHP&amp;MYSQL分页原理及实现
Jan 02 #PHP
默默简单的写了一个模板引擎
Jan 02 #PHP
超强分页类2.0发布,支持自定义风格,默认4种显示模式
Jan 02 #PHP
PHP小技巧搜集,每个PHPer都来露一手
Jan 02 #PHP
实例(Smarty+FCKeditor新闻系统)
Jan 02 #PHP
PHP+JS无限级可伸缩菜单详解(简单易懂)
Jan 02 #PHP
You might like
PHP utf-8编码问题,utf8编码,数据库乱码,页面显示输出乱码
2013/04/08 PHP
php 检查电子邮件函数(自写)
2014/01/16 PHP
php简单的留言板与回复功能具体实现
2014/02/19 PHP
PHP连接数据库实现注册页面的增删改查操作
2016/03/27 PHP
破解Session cookie的方法
2006/07/28 Javascript
[原创]图片分页查看
2006/08/28 Javascript
jquery中防刷IP流量软件影响统计的一点对策
2011/07/10 Javascript
zShowBox 图片放大展示jquery版 兼容性
2011/09/24 Javascript
JQuery 返回布尔值Is()条件判断方法代码
2012/05/14 Javascript
Javascript 判断是否存在函数的方法
2013/01/03 Javascript
JS实现自动固定顶部的悬浮菜单栏效果
2015/09/16 Javascript
整理Javascript流程控制语句学习笔记
2015/11/29 Javascript
AngularJS入门之动画
2016/07/27 Javascript
javascript删除html标签函数cIsHTML
2017/01/09 Javascript
Nodejs+express+ejs简单使用实例代码
2017/09/18 NodeJs
vue input输入框模糊查询的示例代码
2018/05/22 Javascript
深入理解NodeJS 多进程和集群
2018/10/17 NodeJs
JavaScript中CreateTextFile函数
2020/08/30 Javascript
Nuxt 项目性能优化调研分析
2020/11/07 Javascript
[03:12]完美世界DOTA2联赛PWL DAY6集锦
2020/11/05 DOTA
python 快速排序代码
2009/11/23 Python
从Python程序中访问Java类的简单示例
2015/04/20 Python
浅谈python多线程和队列管理shell程序
2015/08/04 Python
Python进阶之全面解读高级特性之切片
2019/02/19 Python
python中安装django模块的方法
2020/03/12 Python
Keras 在fit_generator训练方式中加入图像random_crop操作
2020/07/03 Python
加拿大国民体育购物网站:National Sports
2018/11/04 全球购物
德国消费电子产品购物网站:Guter Kauf
2020/09/15 全球购物
总经理岗位职责
2013/11/09 职场文书
干部考核评语
2014/04/29 职场文书
大学生档案自我鉴定(2篇)
2014/10/14 职场文书
成都人事代理协议书
2014/10/25 职场文书
2014年学校教学工作总结
2014/12/06 职场文书
责任书格式
2015/01/29 职场文书
教师学习中国梦心得体会
2016/01/05 职场文书
只需要这一行代码就能让python计算速度提高十倍
2021/05/24 Python