今天复习了一下  Ajax异步验证用户名是否存在,在下面我写三种,一般开发时候都用第三种 jQuery和Ajax结合的形式,下面就介绍三种,具体说明代码里就有啦,废话不多说,直接上代码:

第一种方式:用基础语法js实现 get请求:

 //封装了获取XMLHttpRequest对象的方法
function getXMLHttpRequest() {
var xmlhttp;
if (window.XMLHttpRequest) {// code for all new browsers
xmlhttp = new XMLHttpRequest();
} else if (window.ActiveXObject) {// code for IE5 and IE6
xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
} return xmlhttp; } <script type="text/javascript" >
function ckName(){
//首先获取用户名对象
var username = document.getElementById("username");
//获取XMLHttpRequest对象
var req = getXMLHttpRequest();
//创建连接
// req.open("get","${pageContext.request.contextPath}/servlet/ckUsernameServlet?username="+username.value,true);
req.open("get","${pageContext.request.contextPath}/servlet/ckUsernameServlet?username="+username.value,true);
//4.发送请求
req.send(null);
//回调函数
req.onreadystatechange = function(){
if(req.readyState==4){
if(req.status==200){
//获取message
var messsage = document.getElementById("message");
if(req.responseText=="true"){
message.innerHTML ="用户名已经存在";
}else{
message.innerHTML ="用户名可以使用";
}
} }
} }
</script> <body>
用户名: <input type="text" name="username" id="username" onblur="ckName()" />
<font id="message">请输入有效的邮箱地址</font>
</body>

Servlet模拟数据库中存在的名字,这里没有连接数据库,就直接模拟了,到实际操作中,直接从数据库中查出名字看是否存在就Ok啦!

package adminServlet;

import java.io.IOException;
import java.io.PrintWriter; import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse; public class CkUsernameServlet extends HttpServlet { public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
request.setCharacterEncoding("UTF-8");
response.setContentType("text/html;charset=UTF-8");
PrintWriter out = response.getWriter(); String username = request.getParameter("username");
System.out.println(username);
if("admin".equals(username)){
out.print(true);
}else{
out.print(false);
} } public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { doGet(request, response);
} }

第二种方式,就改下js代码就好了  post 提交个参数:

function ckName(){
var username = document.getElementById("username");
var req = getXMLHttpRequest();
//创建连接 用post提交方式
req.open("POST","${pageContext.request.contextPath}/servlet/ckUsernameServlet",true);
//向请求添加HTTP头,这个必加,是提交到后台的方式
req.setRequestHeader("Content-type","application/x-www-form-urlencoded");
//把请求发送到服务器
req.send("username="+username.value);
//回调函数
req.onreadystatechange=function(){
if(req.readyState==4 && req.status==200){
var messsage = document.getElementById("message");
if(req.responseText=="true"){
message.innerHTML ="用户名已经存在";
}else{
message.innerHTML ="用户名可以使用";
}
}
}
}

*****第三种方式:最常用的  jQuery 和 Ajax  结合相互使用

   $(document).ready(function(){
$("#username").blur(function(){
// alert($(this).val());
$.post("${pageContext.request.contextPath}/servlet/ckUsernameServlet",{username:$(this).val()},
function(data){
if(data=="true"){ //data 就是从servlet返回来的数据
$("#message").html("用户名已存在");
}else{
$("#message").html("用户名可以注册");
}
}
,"text"); });
});

就这样啦,大家自己练习练习就好咯!

每天都要为自己加油,打气,每天进步一点点,时间长了你就会进步一大截。共勉

Java--- Ajax异步验证用户名是否存在的更多相关文章

  1. ajax异步验证用户名密码,提示路径错误

    使用thinkphp框架异步验证用户名和密码的时候,ajax路径错误可能有多重情况.我遇到的是,我自感路径没问题,且先前使用无错.由于多人合作使用svn,所以在更新代码后,使用firebug显示一直是 ...

  2. Ajax注册验证用户名是否存在 ——引自百度经验

    Ajax注册验证用户名是否存在 http://jingyan.baidu.com/article/a948d6515fdf870a2dcd2e85.html

  3. ssm框架整合+Ajax异步验证

    SSM框架是目前企业比较常用的框架之一,它的灵活性.安全性相对于SSH有一定的优势.说到这,谈谈SSM和SSH的不同点,这也是企业常考初级程序员的面试题之一.说到这两套框架的不同,主要是持久层框架Hi ...

  4. Ajax异步验证登陆或者注册

    首先介绍一个不错的学习Ajax的中文网站:http://www.w3school.com.cn/ajax/index.asp AJAX = 异步 JavaScript 和 XML.详细介绍见上面的网址 ...

  5. php ajax 同时验证 用户名 密码

    今天写了一个程序分享给大家,该程序是ajax密码和用户名验证问题 第一步 先在数据库里建立一张表 有3个字段 为 id name pass 第二步 写html页面,需要引入jq库 请到官网自行下载 & ...

  6. ssh整合问题总结--使用struts2+Ajax+jquery验证用户名是否已被注册

    在用户模块中的用户注册需求上,通常要进行用户名是否已被注册的验证,今天正好写了这个需求,把详细代码和所遇到的问题贴过来.在使用struts2+ajax时候,通常我们会返回json类型的数据,但是像上面 ...

  7. 利用jQuery.validate异步验证用户名是否存在

    转:http://www.cnblogs.com/linzheng/archive/2010/10/14/1851781.html HTML头部引用: <script type="te ...

  8. 请教下 Yii 和 Ajax来验证用户名是否存在

    添加一个 Custom, Model页面: CustomForm中: public function rules() { // 使用ajax 校验数据 return array( array('nam ...

  9. 【java项目实践】具体解释Ajax工作原理以及实现异步验证username是否存在+源代码下载(java版)

    一年前,从不知道Ajax是什么,伴随着不断的积累,到如今常常使用,逐渐有了深入的认识. 今天,假设想开发一个更加人性化,友好,无刷新,交互性更强的网页,那您的目标一定是Ajax. 介绍 在具体讨论Aj ...

随机推荐

  1. docker构建本地仓库后,无法登陆解决办法(CentOS/Ubuntu)

    docker版本为:Server Version: 1.12.6 从dockerhub上下载最新的registry镜像. 首先.构建registry 1.下载registry镜像 docker pul ...

  2. [macOS] keychain的跳坑之旅!git拉取的权限问题

    故事背景,svn与git各有长处,不过git大势所趋吧,那就搞搞.git的服务端,是基于phabricator搭建的,关于它的资料自行google就好了.其实之前运维已经搭好了phabricator了 ...

  3. vim格式化markdown表格

    title: vim格式化markdown表格 date: 2017-11-23 15:23:25 tags: vim categories: 开发工具 安装插件 https://github.com ...

  4. CentOS7+Apache+MySQL+PHP环境

    Apache 1.安装Apache:yum -y install httpd 2.开启apache服务:systemctl start httpd.service 3.设置apache服务开机启动:s ...

  5. 《数据仓库ETL工具箱》读书笔记

    在本书中,你将学习到以下内容: 规划&设计你的ETL系统 从多种可能的架构中选出最合适的 对实施过程进行管理 管理日常的操作 为ETL过程建立开发/测试/生产环境 理解不同的后台数 ...

  6. java static语句的总结

    static 是静态方法,他的引用不需要对象,可以使用类名直接进行引用,当然也不需要this.      由于不需要对象,所以static方法内无法调用非static的方法或对象   至于为什么mai ...

  7. Shell 常用技巧

    Shell 常用技巧 echo $RANDOM | cksum | cut -c - openssl rand -base64 | cksum | cut -c - date +%N | cut -c ...

  8. mysqlbinlog相关

    1.输出binlog到文件mysqlbinlog --base64-output=decode-rows -v /home/mysql/binlog/binlog.000011>/tmp/aa. ...

  9. 1. Dubbo原理解析-Dubbo内核实现之SPI简单介绍 (转)

    转载自  斩秋的专栏  http://blog.csdn.net/quhongwei_zhanqiu/article/details/41577159 Dubbo采用 微内核 + 插件体系,使得设计优 ...

  10. Bugku-CTF之管理员系统+程序员本地网站

    Day12 管理员系统 http://123.206.31.85:1003/ flag格式flag{}