		//密码过滤验证
		var Password = /^[A-Za-z0-9]{6,20}$/;
		//email 过滤验证
		var Email = /^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$/;
		//用户名 过滤验证
		var UserName = /^\w{5,20}$/;


var XMLHttpReq;
       var ResetItem = "";
       //创建XMLHttpRequest对象       
      function createXMLHttpRequest() {
              if(window.XMLHttpRequest) { //Mozilla 浏览器
                     XMLHttpReq = new XMLHttpRequest();
              }
              else if (window.ActiveXObject) { // IE浏览器
                     try {
                           XMLHttpReq = new ActiveXObject("Msxml2.XMLHTTP");
                     } catch(e){
                           try {
                              XMLHttpReq = new ActiveXObject("Microsoft.XMLHTTP");
                           } catch (e) {}
                     }
              }
       }
       //发送请求函数
       function sendRequest(action,userName) {
              createXMLHttpRequest();
            var url = action + userName;
              XMLHttpReq.open("GET", url, true);
              XMLHttpReq.onreadystatechange = processResponse;//指定响应函数
              XMLHttpReq.send(null);  // 发送请求
       }
       // 处理返回信息函数
       function processResponse() {
       if (XMLHttpReq.readyState == 4) { // 判断对象状态
              if (XMLHttpReq.status == 200) { // 信息已经成功返回，开始处理信息
                        DisplayHot();
              }else{
				//other  alert  
			  }
         }
      }
      // 显示更新数据信息的函数
      function DisplayHot() {
			  
      		var content = XMLHttpReq.responseText;
			//非303代表正确、即：已注册用户  如下：else 说明 改用户名 可以使用（没有重复的）
			if(content != "303")
			{
				document.getElementById("userNameFlag").innerHTML = "error";
			}else{
				if(UserName.test(document.getElementById("name").value))
				{
					//设置 用户状态为：ok 通过、说明 改用户名可以使用
					document.getElementById("userNameFlag").innerHTML = "ok";
				}
			}
      }
      //查询用户名是否有重复的
      function searchUserName(value)
      {
		  sendRequest("/checkuser?userName=",value);
      }
	  function timeout()
      {
		  setTimeout("checkUserTrue_viewPage()", 1000);
      }

	  //最后提交时的一个验证/这个方法的目的是在不同浏览器中的效果一样
	  function checkUserTrue_viewPage()
			{
				//决定是否提交
				var flag = "1";
				var name = document.getElementById("name").value;
				var password = document.getElementById("password").value;
				var email = document.getElementById("email").value;
				//获取表单id 对象form
				var formreg = document.getElementById("formreg");
				//记录用户名是否重复状态值分别为：error、ok
				var userNameFlag = document.getElementById("userNameFlag").innerHTML;

				//用户名
				if(name == null || name == "")
				{
					formreg.action = "/reg_step1.jsp";
					formreg.submit();
					return;
				}
				
				//用户名
				if(!UserName.test(name))
				{
					flag = "0";
					alert("用户名应在5-20个字母或数字，不应含其它任意字符");
					return;
				}
				//密码
				if(!Password.test(password))
				{
					flag = "0";
					alert("密码应为6位或6位以上字符");
					return;
				}
				//email、如果email 大于零、如下验证、否则 else
				if(email.length != 0)
				{
					if(!Email.test(email))
					{
						flag = "0";
						alert("请输入正确的邮件地址，该项可选");
						return;
					}
				}
				//验证正确 最后的提交
				if(flag == "1" && userNameFlag == "ok")
				{
					formreg.action = "reg_step2.jsp";
					formreg.submit();
				}else{
					if(userNameFlag == "error")
					{
						alert("该用户名已存在");
					}
					return;
				}
			}