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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/558091.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

同一事务中未提交的写能读到吗_03、MySQL事务的隔离性分析

事务可以用来保证数据库的完整性:要么都做,要么不做。在 MySQL 中,事务支持是在引擎层实现的。你现在知道,MySQL 是一个支持多引擎的系统,但并不是所有的引擎都支持事务。比如 MySQL 原生的 MyISAM 引擎就不支持事务&a…

python软件管理系统_conda:基于python的软件管理系统

python语言在发展的过程中,经历了python2到python3的迁移,对应的包也出现了多个版本。如何在一台服务器上同时安装不同版本的python,不同版本的package, 而且不互相干扰,是一个令人头痛的问题。为了解决这个问题,首先是virtualenv…

vscode远程Mysql数据库_windows系统vscode远程调试mysql

准备工作本文目标是可以从 WindowsVSCode 环境远程访问 Linux 的 mysql源码, 以及执行 GDB 远程调试首先准备以下软件在本地机器上:安装VS Code目前最新版本支持 Remote - Development 插件安装 VSCode 扩展 “Remote - Development”, 方法是左下角管理(⚙) ->扩展, 直接搜…

mysql免安装出现1067_mysql,免安装,1067错误

设置密码关闭正在运行的MySQL。2.打开DOS窗口,转到mysql\bin目录。3.输入mysqld --skip-grant-tables回车。如果没有出现提示信息,那就对了。4.再开一个DOS窗口(因为刚才那个DOS窗口已经不能动了),转到mysql\bin目录。5.输入mysql回车&#x…

python外汇兑换代码_python爬取人民币汇率中间价

python爬取人民币汇率中间价,从最权威的网站中国外汇交易中心。首先找到相关网页,解析链接,这中间需要经验和耐心,在此不多说。以人民币兑美元的汇率为例(CNY/USD),脚本详情如下:windows:# -*- …

python捕捉线程错误_Pythonrequests多线程抓取出现HTTPConnectionPoolMaxretiresexceeded异常...

问题: Python requests 多线程抓取 出现HTTPConnectionPool Max retires exceeded异常描述:主要代码如下:import threadingimport requestsdef get_info():try:res requests.get(http://www.xxx.com/test/json)if res.status_code 200 and res.text ! …

java io 文件路径_【IO流】java中文件路径(相对路径、绝对路径)相关类及方法...

1. URL菜鸟教程:Java URL处理 通常推荐对http等协议进行使用,若操作(file:)部分属性将无意义,建议getFile()。相关:URLConnections 类 可以打开连接进行IO 通过getResource方法可以获得相对于classPath的文件的URL2. FileTestvoid…

java classpath顺序_JVM中类加载顺序及classpath简介

昨天,看一个build Standalone中databrusher的一个脚本,发现一个Java类似乎没有在classpath中,好像也可一直运行了。很疑惑,问了对应的开发同学,然后自己好好看了下它的代码,才知道了原理。命令是&#xff1…

java 过滤脚本_【快学SpringBoot】过滤XSS脚本攻击(包括json格式)

XSS攻击是什么XSS攻击全称跨站脚本攻击,是为不和层叠样式表(Cascading Style Sheets, CSS)的缩写混淆,故将跨站脚本攻击缩写为XSS,XSS是一种在web应用中的计算机安全漏洞,它允许恶意web用户将代码植入到提供给其它用户使用的页面中…

java高级教程_Java高级教程02

1.Java线程1.1. 多线程和多进程多进程:操作系统能够同时进行多个任务: 每个app(word,播放器,浏览器)可以同时运行多线程:同一应用程序中哟多个顺序流同时执行线程是进程中的一部分1.2. 线程的执行过程:主要过程:多线程…

java 带宽控制_如何使用Java netty正确限制带宽使用?

对于我使用netty nio lib在Java中开发的下载客户端,我还实现了带宽限制功能.从技术上讲,我是通过GlobalTrafficShapingHandler对象完成的.基于这个类’JavaDoc我初始化nio客户端管道如下:...trafficHandler new GlobalTrafficShapingHandler(new HashedWheelTimer(…

【LeetCode刷题笔记】动态规划(二)

647. 回文子串 解题思路: 1. 暴力穷举 , i 遍历 [0, N) , j 遍历 [i+1, N] ,判断每一个子串 s[i, j) 是否是回文串,判断是否是回文串可以采用 对撞指针 的方法。如果是回文串就计数 +1

mysql数据库集群备份策略_mysql高可用方案之集群(cluster)

1.实验环境我用三台服务器搭建mysql cluster环境,sql节点和数据节点在同一服务器上,管理节点单独一台.cluster node1:192.168.1.102 data node1:192.168.1.102cluster node2:192.168.1.104 data node2:192.168.1.104manager node:192.168.1.19OS:centos 6.4 64位…

数据结构 排序 java_Java数据结构之排序---选择排序

简单选择排序的介绍:从给定的序列中,按照指定的规则选出某一个元素,再根据规定交换位置后达到有序的目的。简单选择排序的基本思想:假定我们的数组为int [] arr new int[n],第一次我们从arr[0]~arr[n-1]中选择出最小的…

php和java 2017_Php与java的区别

Php与java的区别1.java和php技术层面对比:java是纯面向对象开发,功能强大,分支众多,没有java不能做的软件,PHP有他独特的领域,那就是WEB在这方面没有可以和他相比较,其与java相比较之下在这一方面基本上完胜java因其专注的领域不同所以没有太大可比性,PHP适合于快速开发,中小型…

python百度aip移动目标监控系统_python利用百度云接口实现车牌识别

一个小需求---实现车牌识别。目前有两个想法调云在线的接口或者使用SDK做开发(配置环境和编译第三方库很麻烦,当然使用python可以避免这些问题)自己实现车牌识别算法(复杂)!一开始准备使用百度云文字识别C SDK来做,发现需要准备curl、jsoncpp…

centos tar安装mysql_centos系统通过tar.gz包安装mysql5.7.19

系统:centos6.5 64位系统1、下载mysql本人选的linux generic 通用版 64位2、把mysql传到服务器并解压到/usr/localtar -xzvf mysql-5.7.19-linux-glibc2.12-x86_64.tar -C /usr/local3、进入/usr/local目录:cd /usr/local4、为mysql安装目录创建软链接ln -s mysq…

java6打印机不能用_高分求解:java中调用的打印机在什么情况下不可用?

java文档中说PrinterJob类中的getPrinterJob()方法无论返回的打印机是否可用都不会返回一个null值。我查阅过一些文献有介绍说可以用getPrintService()方法测试返回的数值是否为null来...java文档中说PrinterJob类中的getPrinterJob()方法无论返回的打印机是否可用都不会返回一…

java中算两个时间内的秒数_java – Joda Time – 计算两个日期之间的秒数会引发异常....

我使用以下代码来计算两个日期之间的秒数差异:long secondsBetween (Seconds.secondsBetween(new LocalDate("1901-01-01"), new LocalDate()).getSeconds());但是我得到以下异常:08-08 18:21:27.345: E/AndroidRuntime(6972): java.lang.Run…

java快速排序从小到大_JAVA一个快速排序实现代码

首先排序的方法有很多种:插入排序,冒泡排序,堆排序,归并排序,选择排序,计数排序,基数排序,桶排序,快速排序等这里是主要讲解一下快速排序这个方法,我也是看了…