<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>
<%
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" />