注册时使用ajax检测用户名是否可用

<action name="ajax" class="com.trans.soa.busi.web.AjaxAction" method="check2" />

       今天在改进系统,由于系统注册模块以前没有使用Ajax,用户在注册时填写了一堆信息后可能因为用户名已经存在而前功尽弃,所以今天小试牛刀,在注册原有的基础上使用Ajax增加了对用户名检测是否存在的功能。

 

第一步:创建一个JSP文件——testAjax.jsp

写道
<%@ page language="java" import="java.util.*" pageEncoding="GBK"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<base href="<%=basePath%>">

<title>使用Ajax测试用户名是否存在</title>

<meta http-equiv="pragma" content="no-cache">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="expires" content="0">
<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
<meta http-equiv="description" content="This is my page">
<!--
<link rel="stylesheet" type="text/css" href="styles.css">
-->
<script language="javascript" type="text/javascript">

if (window.ActiveXObject && !window.XMLHttpRequest) {
window.XMLHttpRequest = function() {
return new ActiveXObject((navigator.userAgent.toLowerCase().indexOf('msie 5') != -1) ? 'Microsoft.XMLHTTP' : 'Msxml2.XMLHTTP');
};
}

function testName() {
var username = document.getElementById("username").value;
var view_name = document.getElementById("view_name");
var req = new XMLHttpRequest();
if (req) {
req.onreadystatechange = function() {
if (req.readyState == 4 && req.status == 200) {
if (req.responseText == 0) {
view_name.style.color = 'green';
view_name.innerHTML = '该用户可以使用!';
} else if (req.responseText == 1) {
view_name.style.color= 'red';
view_name.innerHTML = '该用户名已经被使用!';
}
}
}
req.open("POST", "member/ajax!check.do?username="+username);
req.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
req.send("");
}
}
</script>
</head>

<body>
<table>
<tr>
<td>
<input type="text" id="username" name="username">
<input type="button" id="checkBtn" value="检测账号是否可用" οnclick="testName()" />
<div id="view_name"></div>
</td>
</tr>
</table>
</body>
</html>

 

 

第二步:用webwork创建一个Action

import java.io.IOException;
import java.io.PrintWriter;
import java.util.List;

import com.hotye.trans.soa.busi.db.member.entity.Members;
import com.hotye.trans.soa.busi.db.member.service.IMemberService;
import com.hotye.trans.soa.busi.web.action.base.BaseAction;
import com.opensymphony.webwork.ServletActionContext;

public class AjaxAction extends BaseAction {

	private IMemberService memberService;
	
	public String check() throws IOException {
		try {
			PrintWriter pw = ServletActionContext.getResponse().getWriter();
			ServletActionContext.getResponse().setContentType("text/html;charset=GBK");
			String memberName = this.getRequest().getParameter("username");
			List list = memberService.queryMemberByUserId(memberName);
			if (list != null && list.size() > 0) {
				pw.print(1);
			} else {
				pw.print(0);
			}
		} catch (Exception ex) {
			ex.printStackTrace();
		}
		return "";
	}

	public void setMemberService(IMemberService memberService) {
		this.memberService = memberService;
	}
}

 

 

第三步:在xwork-confi.xml中配置该Action

<action name="ajax" class="com.trans.soa.busi.web.AjaxAction" method="check2" />

  

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值