PHP+Ajax异步通讯实现用户名邮箱验证是否已注册( 2种方法实现)


Posted in PHP onDecember 28, 2011

前 言
直接上代码有点不厚道、于是按照天朝传统,整段描述吧。。。。(本人语言表达能力有限,大家忍着看)
功 能
在网站注册用户时使用,主要为了无刷新异步验证用户输入的用户名或者Email是否已注册。
这功能大家肯定见过,大多数网站都有的,我一直对这个功能很感兴趣,所以这几天研究了下 jQuery + Ajax
整了一个功能不算完善,但足以应付普通使用的代码 (更牛的功能大家自己去发掘)
文 件 说 明
reg.php //为注册页面
check_user.php //为用户验证页面 (GET,POST方式任选)
jquery-1.7.1.js //为jQuery文件 下载地址:http://code.jquery.com/jquery-1.7.1.js (右键另存为即可)
代码示例
reg.php 注册页面(内含2种方式,请任选一种)

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 
<html xmlns="http://www.w3.org/1999/xhtml"> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
<title>PHP+Ajax 异步通讯注册验证</title> 
<script type="text/javascript" src="jquery-1.7.1.js"></script> <!--千万别忘记引用jQuery文件,否则无法执行--> 
<script type="text/javascript"> 
$(function(){ 
//方式一 jQuery(普通应用时推荐,简单易用) 
$("#user").blur(function(){ //文本框鼠标焦点消失事件 
$.get("check_user.php?user="+$("#user").val(),null,function(data) //此处get方式 可换为post方式按需求调整,其他无需修改使用方式一样 
{ 
$("#chk").html(data); //向ID为chk的元素内添加html代码 
}); 
}) 
//方式二 aJax方式 (比较复杂,如无特殊需求推荐使用方式一) 
$("#user").blur(function(){ 
$.ajax({ 
url:"check_user.php", //请求验证页面 
type:"GET", //请求方式 可换为post 注意验证页面接收方式 
data:"user="+$("#user").val(), //取得表文本框数据,作为提交数据 注意前面的 user 此处格式 key=value 其他方式请参考ajax手册 
success: function(data) 
{ //请求成功时执行操作 
$("#chk").html(data); //向ID为chk的元素内添加html代码 
} 
}); 
}) 
}) 
</script> 
</head> 
<body> 
<form id="reg" action="" method="post"> 
用户名:<input id="user" type="text" /> <span id="chk"></span> 
</form> 
</body> 
</html>

check_user.php 异步通信页面 代码如下:
<?php 
header("Content-type:text/html;charset=gb2312"); 
//GET方式获取数据(取决于异步提交时提交方式) 
if($_GET['user']) 
{ 
$user=$_GET['user']; 
//此处可进行数据库匹配,本次省略直接判断 
if($user=="admin") 
echo "<font color=red>用户名已被注册!</font>"; 
else 
echo "<font color=red>用户名可以使用</font>"; 
}else{} 
//POST方式获取数据(取决于异步提交时提交方式) 
if($_POST['user']) 
{ 
$user=$_POST['user']; 
//此处可进行数据库匹配,本次省略直接判断 
if($user=="admin") 
echo "<font color=red>用户名已被注册!</font>"; 
else 
echo "<font color=red>用户名可以使用</font>"; 
}else{} 
?>

上面的2种方式分别又存在 post 和 get 两种方式,所以可以说有4种方式选择,应该可以满足普通应用了。
另外关于Ajax 内其他参数例如:请求数据类型,ajax开始操作等等事件。请参考ajax手册。这里不做阐述,较为复杂推荐使用第一种方式。
配 图:

PHP+Ajax异步通讯实现用户名邮箱验证是否已注册( 2种方法实现)      PHP+Ajax异步通讯实现用户名邮箱验证是否已注册( 2种方法实现)

PHP 相关文章推荐
php上传、管理照片示例
Oct 09 PHP
PHP操作文件方法问答
Mar 16 PHP
PHP网站安装程序制作的原理、步骤、注意事项和示例代码
Aug 01 PHP
php递归获取目录内文件(包含子目录)封装类分享
Dec 25 PHP
PHP中设置一个严格30分钟过期Session面试题的4种答案
Jul 30 PHP
php判断类是否存在函数class_exists用法分析
Nov 14 PHP
php获取数组元素中头一个数组元素值的实现方法
Dec 20 PHP
PHPExcel内存泄漏问题解决方法
Jan 23 PHP
PHP页面间传递值和保持值的方法
Aug 24 PHP
利用ajax和PHP实现简单的流程管理
Mar 23 PHP
laravel框架中间件 except 和 only 的用法示例
Jul 12 PHP
laravel 解决后端无法获取到前端Post过来的值问题
Oct 22 PHP
shopex主机报错误请求解决方案(No such file or directory)
Dec 27 #PHP
PHP写UltraEdit插件脚本实现方法
Dec 26 #PHP
url decode problem 解决方法
Dec 26 #PHP
最新用php获取谷歌PR值算法,附上php查询PR值代码示例
Dec 25 #PHP
匹配csdn用户数据库与官方用户的重合度并将重叠部分的用户筛选出来
Dec 25 #PHP
php操作JSON格式数据的实现代码
Dec 24 #PHP
php文件怎么打开 如何执行php文件
Dec 21 #PHP
You might like
便携利器 — TECSUN PL-365简评
2021/03/02 无线电
动态新闻发布的实现及其技巧
2006/10/09 PHP
php_xmlhttp 乱码问题解决方法
2009/08/07 PHP
PHP获取当前相对于域名目录的方法
2015/06/26 PHP
PHP使用pdo实现事务处理操作示例
2018/09/05 PHP
PHP实现微信申请退款功能
2018/10/01 PHP
jQuery 操作XML入门
2008/12/25 Javascript
JS去除字符串的空格增强版(可以去除中间的空格)
2009/08/26 Javascript
js+html+css实现鼠标移动div实例
2013/01/30 Javascript
asp.net刷新本页面的六种方法总结
2014/01/07 Javascript
深入理解JS继承和原型链的问题
2016/12/17 Javascript
jQuery实现可拖拽3D万花筒旋转特效
2017/01/03 Javascript
JSON数据中存在单个转义字符“\”的处理方法
2018/07/11 Javascript
为jquery的ajax请求添加超时timeout时间的操作方法
2018/09/04 jQuery
详解Vue中CSS样式穿透问题
2019/09/12 Javascript
Vue.js组件props数据验证实现详解
2019/10/19 Javascript
原生JS无缝滑动轮播图
2019/10/22 Javascript
使用 Angular RouteReuseStrategy 缓存(路由)组件的实例代码
2019/11/01 Javascript
vue+element导航栏高亮显示的解决方式
2019/11/12 Javascript
详解小程序横屏方案对比
2020/06/28 Javascript
编写Python的web框架中的Model的教程
2015/04/29 Python
Python中Threading用法详解
2017/12/27 Python
Python机器学习之SVM支持向量机
2017/12/27 Python
matlab中实现矩阵删除一行或一列的方法
2018/04/04 Python
Python FFT合成波形的实例
2019/12/04 Python
pytorch之inception_v3的实现案例
2020/01/06 Python
opencv-python的RGB与BGR互转方式
2020/06/02 Python
Windows环境下Python3.6.8 importError: DLLload failed:找不到指定的模块
2020/11/01 Python
基于CSS3的animation属性实现微信拍一拍动画效果
2020/06/22 HTML / CSS
美国和加拿大房车出售在线分类广告:RVT.com
2018/04/23 全球购物
安全教育心得体会
2013/12/29 职场文书
六查六看自查材料
2014/02/17 职场文书
加强机关作风建设心得体会
2014/10/22 职场文书
2015年基层党组织公开承诺书
2015/01/21 职场文书
学生会生活部工作总结2015
2015/03/31 职场文书
JVM上高性能数据格式库包Apache Arrow入门和架构详解(Gkatziouras)
2021/05/26 Servers