效果图展示:
异步(Asynchronous)的概念和同步(Synchronous)相对。当一个异步过程调用发出后,调用者不需要立刻得到结果,可以继续做自己的事情,等到过程调用完毕,再通过回调函数通知调用方。而同步情况下,调用方必须等待对方得到结果,才能继续运行
具体解释参考http://www.w3school.com.cn/ajax/
前台代码
<%@ page language="java" import="java.util.*" pageEncoding="gbk"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<meta http-equiv="content-type" content="text/html; charset=gbk">
<title>welcome ,注册本系统</title>
<link rel="stylesheet" type="text/css" href="style/style.css">
<script type="text/javascript">
var xhr=null;
function checkUname(){
var username=document.myform.uname.value;
//alert(username);
if(username==""||username==null){
document.getElementById("msgDiv").innerHTML="<font color='red'>请输入用户名</font>";
}
//ajax的核心对象
//var xhr=new XMLHttpRequest();//只对非ie浏览器生效
if(window.ActiveXObject){
xhr=new ActiveXObject("Microsoft.XMLHTTP");
}else{
xhr=new XMLHttpRequest();
}
var url="http://localhost:8080/12softsms0415/RegServlet?uname="+username;
//当核心对象的状态发生改变,它的处理函数
xhr.onreadystatechange=haolejiaowo;
xhr.open("get",url,true);
xhr.send(null);
}
//才是核心处理函数
function haolejiaowo(){
if(xhr.readyState==4&&xhr.status==200){
var result=xhr.responseText;//得到远程服务器返回的结果
if(result.indexOf("true")!=-1){
alert(result);
document.getElementById("msgDiv").innerHTML="<font color='red'>用户名已存在</font>";;
}else{
document.getElementById("msgDiv").innerHTML="可以注册";
}
}
}
</script>
</head>
<body>
<div align="center">
<%-- 登录 --%>
<div class="login" align="center">
<br/>
<h2>短信系统注册</h2>
<form action="UserServlet" method="post" name="myform">
<input type="hidden" name="cmd" value="reg">
用户名<input type="text" name="uname" class="input" οnblur="checkUname()"/>
<div id="msgDiv" style="display:inline">提示信息</div>
<br/>
密 码<input type="password" name="upass" class="input"/><br/>
重复密码<input type="password" name="upassrep" class="input"/><br/>
<input type="submit" value=" 注册 " class="btn"/>
</form>
</div>
</div>
</body>
</html>
Servlet核心代码
public boolean isExist(String username){
//模拟后台数据库有三个用户
String[] names={"jack","rose","marry","12210810235"};
for (String s : names) {
if(username.equalsIgnoreCase(s)){
return true;
}
}
return false;
}
doGet()方法