php mysql ajax 注册验证 实例_Ajax小实例   用户注册异步验证

简介

51cto的程序员应该都有sina微博吧!你会发现当你更改新浪会员名称,输入用户名Tab后,光标焦点移动到密码输出框时,用户名输出框的后面,就已经显示出了验证。验证信息是:你的用户名是否唯一,因为新浪微博和腾讯微博不一样,她的会员用户名都是唯一的,这样好将用户区分开,达到没有重名的目的。

如果用户名已被注册,就显示“用户名已存在”,用户名还没被注册,就显示“用户名可用”。

1224853ec7b339f9994591480159ac06.png

实现原理

1、当光标焦点移动到别处时,触发js的window.onblur事件,调用Ajax对象

2、将用户名框内的字符串(document.getElementById(id).value)提交到后台页面

3、与相应数据库里的数据进行比对,再将比对结果返回到界面上,呈现我们面前的就是上面那样的画面。

好处:实现页面的局部刷新,在全部提交到后台前,提前验证并给出结果,提高了输出的效率。

下面不说那么多了,直接上代码:

demo.html前端页面就一个用户名输出框(很简单吧!关键是弄懂原理)

public.js封装了对不同浏览器、创建不同Ajax对象的方法

ajax.js      Ajax对象的封装、方法的实现

demo.php后台页面主要实现接收数据、选择并连接数据库、判断接收的数据与数据库比对

demo.html

用户输入

用户名:

public.jsfunction createxhr(){

try{return new ActiveXObject("Microsoft.XMLHTTP")}catch(e){}

try{return new XMLHttpRequest}catch(e){}

alert("请更换浏览器");

}

//获取DOM对象的id值

function $(id){

return document.getElementById(id);

}

ajax.jsfunction response(){

$('username').onblur = function(){

var uname = this.value; //面向对象编程,this指代"$('username')"

var xhr = createxhr();

//应用getTime()方法解决IE缓存问题

var url = "demo.php?username="+uname+'&_'+new Date().getTime();

xhr.open('get',url);

xhr.onreadystatechange = function(){

if (xhr.readyState == 4 && xhr.status == 200){

var value = xhr.responseText;

if (value == 1){

$('msg').innerHTML = '用户名已存在';

}else{

$('msg').innerHTML = '用户名可用';

}

}

};

xhr.send(null);

};

};

demo.php//接收传递数据

$username = $_GET['username'];

//连接、选择数据库

mysql_connect('localhost','root','111111');

mysql_select_db('shop');

mysql_query('set names gb2312');

//sql语句、执行

$sql = "select * from users where username='$username'";

$result = mysql_query($sql);

$num = mysql_num_rows($result);//获得结果集的行数

//判断结果集行数

if($num>0){

echo 1;

}else{

echo 2;

}

查看结果:

92e92b4cc2b3c475530e44976f652b60.png

dfbcffa2753e60f17088204dc021f522.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
下面是一个基于 AJAX用户注册信息异步校验的示例代码: HTML 代码: ```html <form id="register-form" method="post"> <label for="username">用户名:</label> <input type="text" name="username" id="username"> <span id="username-error"></span> <br> <label for="email">邮箱:</label> <input type="email" name="email" id="email"> <span id="email-error"></span> <br> <label for="password">密码:</label> <input type="password" name="password" id="password"> <span id="password-error"></span> <br> <input type="submit" value="注册"> </form> ``` JavaScript 代码: ```javascript $(document).ready(function() { // 当表单提交时,阻止默认行为并执行异步校验 $('#register-form').submit(function(event) { event.preventDefault(); // 获取表单数据 var username = $('#username').val(); var email = $('#email').val(); var password = $('#password').val(); // 发送 AJAX 请求 $.ajax({ url: 'register.php', type: 'post', data: { username: username, email: email, password: password }, dataType: 'json', success: function(response) { // 根据响应结果更新错误提示信息 if (response.username_error) { $('#username-error').text(response.username_error); } else { $('#username-error').text(''); } if (response.email_error) { $('#email-error').text(response.email_error); } else { $('#email-error').text(''); } if (response.password_error) { $('#password-error').text(response.password_error); } else { $('#password-error').text(''); } // 如果没有任何错误,则重定向到登录页 if (!response.errors) { window.location.href = 'login.php'; } } }); }); }); ``` PHP 代码: ```php <?php // 连接数据库 $pdo = new PDO('mysql:host=localhost;dbname=test', 'root', ''); // 获取表单数据 $username = $_POST['username']; $email = $_POST['email']; $password = $_POST['password']; // 检查用户名是否已存在 $stmt = $pdo->prepare('SELECT COUNT(*) FROM users WHERE username = ?'); $stmt->execute([$username]); if ($stmt->fetchColumn()) { $errors['username_error'] = '用户名已存在'; } // 检查邮箱是否已被注册 $stmt = $pdo->prepare('SELECT COUNT(*) FROM users WHERE email = ?'); $stmt->execute([$email]); if ($stmt->fetchColumn()) { $errors['email_error'] = '邮箱已被注册'; } // 检查密码是否符合要求 if (strlen($password) < 6) { $errors['password_error'] = '密码长度不能少于 6 个字符'; } // 如果存在错误,则返回错误信息,否则创建新用户并返回成功信息 if (!empty($errors)) { $response['errors'] = true; $response += $errors; } else { $stmt = $pdo->prepare('INSERT INTO users (username, email, password) VALUES (?, ?, ?)'); $stmt->execute([$username, $email, $password]); $response['success'] = true; } // 返回 JSON 格式的响应 header('Content-Type: application/json'); echo json_encode($response); ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值