Ajax中模拟注册效果

通过Ajax的异步请求将用户名提交到服务器,服务器端查询数据库,若该用户名不存在,则可注册;否则不能注册。而此时页面无须刷新。

register.jsp

<%@ page language="java"  pageEncoding="utf-8"%>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
	<head>
		<title>校验用户名是否存在</title>
		<script type="text/javascript" src="./register.js"> </script>
	</head>
	<body>
	<center>
	<form action=""  enctype="application/x-www-form-urlencoded">
		<h3>请填写用户注册信息</h3>
		<table  border="1">
			<tr>
				<td>用户名:</td>
				<td><input type="text" name="username" value="" id="username">
				  <div id="divcheck"></div>
				  <input type="button" name="checkusername" value="查看用户名" id="checkusername"></td>
			</tr>
			<tr>
				<td>密码:</td>
				<td><input type="password" name="psw" value=""></td>
			</tr>
			<tr>
				<td>确认密码:</td>
				<td><input type="password" name="confpsw" value=""></td>
			</tr>
			<tr>
				<td>出生日期:</td>
				<td><input type="text" name="birthday" value=""></td>
			</tr>
		</table>
		 </form>
		 </center>
	</body>
	
</html>
register.js

window.onload = function(){
	document.getElementById("checkusername").onclick = function(){
		var username = document.getElementById("username").value;
		
		var xhr = ajaxFunction();
		
		xhr.onreadystatechange = function(){
			if(xhr.readyState==4){
				if(xhr.status==200){
					var data = xhr.responseText;
					
					document.getElementById("divcheck").innerHTML = data;
					
				}
			}
		}
		
		xhr.open("post","../registerServlet?timeStamp="+new Date().getTime(),true);
		
		xhr.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
		
		xhr.send("username="+username);
		
	}
	
	function ajaxFunction(){
	   var xmlHttp;
	   try{ // Firefox, Opera 8.0+, Safari
	        xmlHttp=new XMLHttpRequest();
	    }
	    catch (e){
		   try{// Internet Explorer
		         xmlHttp=new ActiveXObject("Msxml2.XMLHTTP");
		      }
		    catch (e){
		      try{
		         xmlHttp=new ActiveXObject("Microsoft.XMLHTTP");
		      }
		      catch (e){}
		      }
	    }
	
		return xmlHttp;
	 }
}
RegisterServlet.java

package app.servlet;

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 RegisterServlet extends HttpServlet {

	public void doPost(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {

		response.setContentType("text/html;charset=utf-8");
		PrintWriter out = response.getWriter();
		
		//1 获取到请求的数据内容:username
		String username = request.getParameter("username");
		
		System.out.println("username = "+username);
		
		//2 查询数据库:1)结果集为空,用户名可用;2)结果集不为空,用户名不可用
		
		//模拟查询数据库
		if(username==null||"".equals(username)){
			out.println("请输入你的用户名!");
		}else if(username.equals("sa")){
			out.println("该用户名已存在!");
		}else{
			out.println("该用户名可使用!");
		}
		
	}

}




基于可靠性评估序贯蒙特卡洛模拟法的配电网可靠性评估研究(Matlab代码实现)内容概要:本文围绕“基于可靠性评估序贯蒙特卡洛模拟法的配电网可靠性评估研究”,介绍了利用Matlab代码实现配电网可靠性的仿真分析方法。重点采用序贯蒙特卡洛模拟法对配电网进行长时间段的状态抽样与统计,通过模拟系统元件的故障与修复过程,评估配电网的关键可靠性指标,如系统停电频率、停电持续时间、负荷点可靠性等。该方法能够有效处理复杂网络结构与设备时序特性,提升评估精度,适用于含分布式电源、电动汽车等新型负荷接入的现代配电网。文中提供了完整的Matlab实现代码与案例分析,便于复现和扩展应用。; 适合人群:具备电力系统基础知识和Matlab编程能力的高校研究生、科研人员及电力行业技术人员,尤其适合从事配电网规划、运行与可靠性分析相关工作的人员; 使用场景及目标:①掌握序贯蒙特卡洛模拟法在电力系统可靠性评估中的基本原理与实现流程;②学习如何通过Matlab构建配电网仿真模型并进行状态转移模拟;③应用于含新能源接入的复杂配电网可靠性定量评估与优化设计; 阅读建议:建议结合文中提供的Matlab代码逐段调试运行,理解状态抽样、故障判断、修复逻辑及指标统计的具体实现方式,同时可扩展至不同网络结构或加入更多不确定性因素进行深化研究。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值