在开发在线收费系统时,因为考及时显示所有在线用户,所以采用了AJAX来实现,这是我的一点体会
Ajax代码如下:
<script language="JavaScript" type="">
var XMLHttpReq = false;
//创建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()...{
var url="handlerList.do"
createXMLHttpRequest(); //调用创建对象方法
XMLHttpReq.open("post",url,true);
XMLHttpReq.onreadystatechange = processResponse;//指定响应函数 调用
XMLHttpReq.setRequestHeader("If-Modified-Since","0");
XMLHttpReq.send(null);//发送请求
}
//处理返回信息函数
function processResponse()...{
if(XMLHttpReq.readyState==4)...{//代表服务器已经传回所有的信息,可以处理了
if(XMLHttpReq.status==200)...{ //信息已经成功返回,开始处理信息
updateTable();
setInterval("sendRequest()",10000);
}else //页面不正常
window.alert("您所请求的页面有异常。");
}
}
//更新table的内容
function updateTable()...{
clearTable();
var results=XMLHttpReq.responseXML.getElementsByTagName("handler");
for(var i=0;i<results.length;i++)...{
var name=results[i].childNodes[0].firstChild.nodeValue;
addTableRow(name);
}
}
//向table的行添加单元格
function addTableRow(name)...{
var table=document.getElementById("handlerList");
var row = table.insertRow(1);
var cell = row.insertCell(0);
cell.align="center";
cell.innerHTML="<strong>"+name+"</strong>";
}
//清除表格内容
function clearTable()...{
var table=document.getElementById("handlerList");
for(var i=table.rows.length-1;i>0;i--)
...{
table.deleteRow(i);
}
}
</script>
下面是JSP的内容
<body onload="sendRequest()">
<table width = "124" height="100%" border="0" cellspacing="0" background="../image/bak.jpg">
<tr>
<td height="39" align="center" valign="middle"><p align="center"><html:link forward="main"><strong>业务受理</strong></html:link></p>
</td>
</tr>
<tr>
<td height="36" align="center" valign="middle"><html:link forward="payMoney"><strong>业务处理</strong></html:link></td>
</tr>
<tr>
<td height="35" align="center" valign="middle"><html:link forward="query"><strong>业务查询</strong></html:link></td>
</tr>
<tr>
<td height="35" align="center" valign="middle"><html:link forward="update"><strong>资料修改</strong></html:link></td>
</tr>
<tr>
<td height="42" align="center" valign="middle"><strong><html:link href="admin.jsp">管理</html:link></strong></td>
</tr>
<tr>
<td height="34" align="center" valign="middle"><strong><br>
退出</strong>
</td>
</tr>
<tr>
<td height="21" align="center" valign="middle">
</td>
</tr>
<tr>
<td align="center" valign="middle">
<table id="handlerList" width="100%" height="20" border="0" cellpadding="0" cellspacing="0">
<tr>
<td align="center"><strong>在线人员:</strong></td>
</tr>
</table>
</td>
</tr>
</table>
</body>
handlerListAction内容如下
public ActionForward execute(ActionMapping mapping, ActionForm form,
HttpServletRequest request, HttpServletResponse response) ...{
try ...{
request.setCharacterEncoding("GBK");
} catch (UnsupportedEncodingException e) ...{
// TODO Auto-generated catch block
e.printStackTrace();
}
response.setContentType("text/xml;charset=GBK");
response.setHeader("Cache-Control","no-cache");
ServletContext context=getServlet().getServletContext();
List list=(List)context.getAttribute("onlineHandler");
PrintWriter out = null;
try ...{
out = response.getWriter();
} catch (IOException e) ...{
// TODO Auto-generated catch block
e.printStackTrace();
}
String str="";
str="<?xml version="1.0" encoding="GBK"?>";
str+="<handlers>";
for(int i=0;i<list.size();i++)
...{
str+="<handler>";
Handler handler=(Handler)list.get(i);
str+="<name>"+handler.getHandlerName()+"</name>";
str+="</handler>";
}
str+="</handlers>";
out.println(str);
out.close();
return null;
}
为了实现对在线人员的统计
我在登陆的时候将登陆人员放入了ServletContext中,然后使用HttpSessionListenter来监视登陆用户情况
public class SessionListenter implements HttpSessionListener ...{
public SessionListenter()
...{}
public void sessionCreated(HttpSessionEvent arg0) ...{
// TODO Auto-generated method stub
System.out.println("Session监听启动了");
arg0.getSession().setMaxInactiveInterval(1*60);//设置Session的过期时间为1分钟
}
public void sessionDestroyed(HttpSessionEvent arg0) ...{
System.out.println("session释放启动了");
HttpSession session = arg0.getSession();
ServletContext ctx = session.getServletContext();
List list = (List)ctx.getAttribute("onlineHandler");
list.remove(session.getAttribute("handler"));
System.out.println("List的个数为:"+list.size());
}
分享到:
相关推荐
AJAX实现用户登录注册(Struts+Spring+Hibernate+Ajax框架) AJAX实现用户登录注册(Struts+Spring+Hibernate+Ajax框架) AJAX实现用户登录注册(Struts+Spring+Hibernate+Ajax框架)
**jQuery+Struts+Ajax无刷新分页** 在Web应用开发中,为了提供更好的用户体验,无刷新分页已经成为一种常见的需求。本项目采用jQuery、Struts2和Ajax技术实现了这样一个功能,用户可以在不重新加载整个页面的情况下...
Struts、Hibernate和Ajax是Java ...总之,“Struts+Hibernate+Ajax注册示例”是一个综合性的学习项目,它涵盖了Web开发中的多个重要组件,通过实践可以帮助开发者更好地理解和掌握这些技术,提高开发效率和应用质量。
在描述中提到的“Struts+ajax的增删查改”,意味着我们将看到如何在Struts框架下利用Ajax实现对数据的动态操作。 1. **增加(Create)**:在传统的Struts应用中,用户填写表单后提交,页面会跳转到新的结果页面。而...
8. 实例演示:使用Struts2+Jquery+Ajax实现动态加载数据或表单验证 "struts2 jar"文件包含了Struts2框架的核心库,可能包括struts2-core、struts2-convention、struts2-json-plugin等依赖,这些是开发Struts2应用必...
而AJAX(Asynchronous JavaScript and XML)则允许网页在不刷新整个页面的情况下与服务器交换数据并更新部分网页内容,从而实现异步交互。 在这个实例中,我们使用AJAX来实时检测用户输入的用户名是否已经在数据库...
在这个"struts2+ajax实现无刷新登录"的项目中,我们首先会涉及到Struts2的基本配置。在Struts2中,你需要创建一个配置文件(如struts.xml),在这里定义Action类以及它们与URL的映射关系。Action类是处理用户请求的...
在"Struts2+Ajax实现的用户登录"场景中,首先,我们需要在Struts2的配置文件(struts.xml)中定义一个Action,这个Action将处理用户的登录请求。Action通常会包含一个方法,比如`execute()`,该方法会在用户提交登录...
JAVA struts+hibernate实现的网络购物系统JAVA struts+hibernate实现的网络购物系统JAVA struts+hibernate实现的网络购物系统JAVA struts+hibernate实现的网络购物系统JAVA struts+hibernate实现的网络购物系统JAVA ...
总结来说,"struts+ajax分页程序"是一个结合了Struts框架和Ajax技术的Web应用程序,实现了用户交互过程中无需刷新整个页面的动态分页效果。通过Struts处理业务逻辑和数据查询,以及Ajax负责异步通信,提升了用户体验...
在这个"一个struts+Ajax实现的抽奖程序"中,我们可以推测以下关键知识点: 1. **Struts框架**:Struts 1.2是较早版本的Struts框架,它通过ActionServlet处理HTTP请求,并将请求分发给相应的Action,Action处理业务...
综上所述,"简单公文管理 struts+spring+ibatis +ajax 分页"是一个集成了多种技术的Web应用,它利用Struts进行页面控制,Spring管理业务逻辑,iBatis处理数据访问,Ajax提升用户体验,共同构建了一个高效、易用的...
struts + spring + hibernate + velocity + ajax + jotm + acegi
【标题】"ZTree+Struts2+ajax+json实现checkbox权限树"涉及的技术栈主要集中在前端的ZTree,后端的Struts2框架,以及数据交互中的Ajax和JSON。这个项目的核心目标是构建一个可复选的权限树形结构,用户通过勾选节点...
根据网络在线考试系统的特点,可以将其分为前台和后台两个部分进行设计。前台主要用于考生注册和登录系统、在线考试、查询成绩以及修改个人资料等;后台主要用于管理员对考生信息、课程信息、考题信息和考生成绩信息...
通过学习和实践这个"Struts+Jndi+Ajax"的示例,初学者可以更好地理解这三者如何协同工作,构建出功能丰富的Web应用。了解和掌握这些技术对于成为一名合格的Java Web开发者至关重要,因为它们在实际开发中被广泛使用...
在这个"Struts+Spring+Hibernate+Ajax的Demo"中,开发者使用了这些技术来创建一个功能丰富的示例应用。下面将详细阐述这四种技术以及DWR和Dojo在其中的作用。 **Struts** 是一个开源的MVC(Model-View-Controller)...
本文将深入探讨如何利用AJAX技术来实现网页的定时刷新功能,同时结合JSP的后端处理,以提高用户体验。 首先,了解AJAX的核心概念。AJAX是一种不重新加载整个页面的情况下更新部分网页的技术。它通过XMLHttpRequest...
论坛系统项目(Struts 2+Hibernate+Spring实现)论坛系统项目(Struts 2+Hibernate+Spring实现)论坛系统项目(Struts 2+Hibernate+Spring实现)论坛系统项目(Struts 2+Hibernate+Spring实现)论坛系统项目(Struts...