Ajax实例之校验用户名是否已被注册

1.功能介绍

在注册表单中,当用户填写了用户名,把光标移开后,会自动向服务器发送异步请求。服务器返回true或false,返回true表示这个用户名已经被注册过,返回false表示没有注册过。

客户端得到服务器返回的结果后,确定是否在用户名文本框后显示“该用户名已被注册”的错误信息!

2.代码实现

  • regist.jsp页面中给出注册表单,给username表单字段的onblur事件注册监听,调用XMLHttpRequest对象的send()方法,向服务器发送异步请求,参数为username。

<%@ page language="java" contentType="text/html; charset=UTF-8"
	pageEncoding="UTF-8"%>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>ajax实例:用户名是否已被注册</title>
<script type="text/javascript" src="../js/jquery-1.11.0.js"></script>
<script type="text/javascript">
	
    //1.创建异步对象(XMLHttpRequest对象)
    function createXMLHttpRequest() {
	try {

	    // 适用于大多数浏览器,以及IE7和IE更高版本
	    return new XMLHttpRequest();
	} catch (e) {
	    try {

		// 适用于IE6.0
		return new ActiveXObject("Msxml2.XMLHTTP");
	    } catch (e) {
		try {

		    // 适用于IE5.5及更早版本
		    return new ActiveXObject("Microsoft.XMLHTTP");
		} catch (e) {
		    throw e;
		}
	    }
	}
    }
	
    // 文档加载完成事件
    window.onload = function() {
		
        // 获取用户名文本框,给它的失去焦点事件注册监听
        var usernameEle = document.getElementById("username");
        usernameEle.onblur = function() {
			
            // 2.调用XMLHttpRequest对象的open()方法,打开与服务器的连接
            var xmlHttp = createXMLHttpRequest();
            xmlHttp.open("POST", "<c:url value='/RegistServlet'/>", true);
			
            // 设置Content-Type请求头
            xmlHttp.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
			
            // 3.调用XMLHttpRequest对象的send()方法,发送请求,发送时指定请求体
            xmlHttp.send("username=" + usernameEle.value);
			
            //4.XMLHttpRequest对象的onreadystatechange事件,会在XMLHttpRequest对象的状态发生变化时被调用
            xmlHttp.onreadystatechange = function() {
	        if (xmlHttp.readyState == 4 && xmlHttp.status == 200) {

	            // 5.通过XMLHttpRequest对象的responseText得到服务器的响应内容
	            var text = xmlHttp.responseText;
					
	            // 得到span元素
	            var spanEle = document.getElementById("msg");
					
	            if (text == "true"){
		        spanEle.innerHTML = "<font color='red'>该用户名已被注册</font>";
	            } else {
		        spanEle.innerHTML = "<font color='green'>该用户名可用</font>";
	            }
	        }
            };
        };
    };
</script>
</head>
<body>
    <form action="#" method="post">
        <table>
	    <tr>
		<td>用户名:</td>
		<td><input type="text" name="username" id="username"/></td>
		<td><span id="msg"></span></td>
	    </tr>
	    <tr>
		<td>密码:</td>
		<td><input type="password" name="password"/></td>
	    </tr>
	</table>
    </form>
</body>
</html>
  • RegistServlet:获取username参数,判断是否为“allan”,如果是响应true,否则响应false;
package cn.itcast.servlet;

import java.io.IOException;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

public class RegistServlet extends HttpServlet {

    public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        request.setCharacterEncoding("utf-8");
	response.setContentType("text/html;charset=utf-8");
		
	// 获取表单输入项
	String username = request.getParameter("username");
		
	if (username.equalsIgnoreCase("allan")) {
	    response.getWriter().write("true");
	} else {
	    response.getWriter().write("false");
	}
    }

}

3.实现效果

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小蝌蚪找玛玛

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值