|
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
到时我们不用学struts,不用学spring,不用学Hibernate,只要能把jsf学会了,完全可以替代所有的框架,包括AJAX,都知道AJAX并不是新技术,虽说我没深入学习jsf但我认为jsf应该已经能通过其它技术替代AJAX,实现无缝刷新。servlet|session捕捉Session事务的意义:
1、纪录网站的客户登录日记(登录,加入信息等)
2、统计在耳目数
3、等等另有良多,呵呵,本人想吧……总之挺主要的。
Session代表客户的会话历程,客户登录时,往Session中传进一个对象,便可跟踪客户的会话。在Servlet中,传进Session的对象假如是一个完成HttpSessionBindingListener接口的对象(便利起见,此对象称为监听器),则在传进的时分(即挪用HttpSession对象的setAttribute办法的时分)和移往的时分(即挪用HttpSession对象的removeAttribute办法的时分或SessionTimeout的时分)Session对象会主动挪用监听器的valueBound和valueUnbound办法(这是HttpSessionBindingListener接口中的办法)。
由此可知,登录日记也就不难完成了。
别的一个成绩是,怎样统计在耳目数,这个成绩跟完成登录日记略微有点分歧,统计在耳目数(及其信息),就是统计如今有几个Session实例存在,我们能够增添一个计数器(假如想存储更多的信息,能够用一个对象来做计数器,随后给出的实例中,复杂起见,用一个整数变量作为计数器),经由过程在valueBound办法中给计数器加1,valueUnbound办法上钩数器减1,便可完成在耳目数的统计。固然,这内里要使用到ServletContext的全局特征。(有关ServletContext的叙说请参考Servlet标准),新建一个监听器,并将实在例存进ServletContext的属性中,以包管此监听器实例的独一性,当客户登录时,先判别ServletContext的这个属性是不是为空,假如不为空,证实已创立,间接将此属性掏出放进Session中,计数器加1;假如为空则创立一个新的监听器,并存进ServletContext的属性中。
举例申明:
完成一个监听器:
//SessionListener.java
importjava.io.*;
importjava.util.*;
importjavax.servlet.http.*;
//监听登录的全部历程
publicclassSessionListenerimplementsHttpSessionBindingListener
{
publicStringprivateInfo="";//天生监听器的初始化参数字符串
privateStringlogString="";//日记纪录字符串
privateintcount=0;//登录人数计数器
publicSessionListener(Stringinfo){
this.privateInfo=info;
}
publicintgetCount(){
returncount;
}
publicvoidvalueBound(HttpSessionBindingEventevent)
{
count++;
if(privateInfo.equals("count"))
{
return;
}
try{
Calendarcalendar=newGregorianCalendar();
System.out.println("LOGIN:"+privateInfo+"TIME:"+calendar.getTime());
logString="
LOGIN:"+privateInfo+"TIME:"+calendar.getTime()+"
";
for(inti=1;i<1000;i++){
Filefile=newFile("yeeyoo.log"+i);
if(!(file.exists()))
file.createNewFile();//假如文件不存在,创立此文件
if(file.length()>1048576)//假如文件年夜于1M,从头创立一个文件
continue;
FileOutputStreamfoo=newFileOutputStream("yeeyoo.log"+i,true);//以append体例翻开创立文件
foo.write(logString.getBytes(),0,logString.length());//写进日记字符串
foo.close();
break;//加入
}
}catch(FileNotFoundExceptione){}
catch(IOExceptione){}
}
publicvoidvalueUnbound(HttpSessionBindingEventevent)
{
count--;
if(privateInfo.equals("count"))
{
return;
}
try{
Calendarcalendar=newGregorianCalendar();
System.out.println("LOGOUT:"+privateInfo+"TIME:"+calendar.getTime());
logString="
LOGOUT:"+privateInfo+"TIME:"+calendar.getTime()+"
";
for(inti=1;i<1000;i++){
Filefile=newFile("yeeyoo.log"+i);
if(!(file.exists()))
file.createNewFile();//假如文件不存在,创立此文件
if(file.length()>1048576)//假如文件年夜于1M,从头创立一个文件
continue;
FileOutputStreamfoo=newFileOutputStream("yeeyoo.log"+i,true);//以append体例翻开创立文件
foo.write(logString.getBytes(),0,logString.length());//写进日记字符串
foo.close();
break;//加入
}
}catch(FileNotFoundExceptione){}
catch(IOExceptione){}
}
}
登录日记的完成:
上面再来看看我们的登录Servlet中利用这个监听器的部分源代码:
……
HttpSessionsession=req.getSession(true);
……
///////////////////////////////////////////////////////////////////////
SessionListenersessionListener=newSessionListener("IP:"+req.getRemoteAddr());//关于每个会话历程均启动一个监听器
session.setAttribute("listener",sessionListener);//将监听器植进HttpSession,这将引发监听器挪用valueBound办法,从而纪录日记文件。
///////////////////////////////////////////////////////////////////////
当体系加入登录时,只需复杂地挪用session.removeAttribute(“listener”);便可主动挪用监听器的valueUnbound办法。大概,当SessionTimeOut的时分也会挪用此办法。
登录人数的统计:
ServletContextsession1=getServletConfig().getServletContext();//获得ServletContext对象实例
if((SessionListener)session1.getAttribute("listener1")==null)
{
SessionListenersessionListener1=newSessionListener("count");//只设置一次,分歧于下面日记文件的纪录每次会话均设置。即当第一个客户毗连到服务器时启动一个全局变量,今后一切的客户将利用不异的高低文。
session1.setAttribute("listener1",sessionListener1);//将监听器对象设置成ServletContext的属性,具有全局局限无效性,即一切的客户都可以获得它的实例。
}
session.setAttribute("listener1",(SessionListener)session1.getAttribute("listener1"));//掏出此全局对象,而且将此对象绑定到某个会话中,此举将促使监听器挪用valueBound,计数器加一。
在今后的程序中随时能够用以下代码获得以后的登录人数:
((SessionListener)session.getAttribute("listener1")).getCount()
getCount()是监听器的一个办法,即获得以后计数器的值也就是登录人数了。
主要缺点就是:速度比较慢,没有C和C++快 |
|