Session|xml
This topic contains a lot of concepts to explain, the easiest to say is "in-station message", which is the function of many forums, can send messages to other online users through the Web, many users have used. The first advantage of information in the station is that we do not need to install the client, you do not have to know the other's MSN or QQ, you can contact him, praise his views or give him a scolding. The second advantage is customer management convenience, using session to maintain online lists, the various scripts have already encapsulated the session operation is very easy to use, without the same as other stateless instant messaging tools (such as using UDP communication tools), it costs some brain cells to solve the problem of online lists. The disadvantage is that the real-time is not good, generally in the user jump or refresh the page to detect messages, update the online list.
Session listening, there is nothing to explain, Java provides a very flexible event mechanism to listen to the session, you can listen to the creation and destruction of sessions, monitoring the session of the data carried by the creation, change and destruction, You can monitor the sharpening and passivation of the session (the brother who understands object serialization should know this), the other platform is a case I'm not sure, I guess. If you can monitor all of your clients ' sessions, you won't have to go through the hassle-free application.
XMLHTTP is a technology of MS Push, the function is very complex, can do a lot of things, such as the client can open the HTTP connection in the simple HTML, the initiative to request data from the server and get the return data, is a very important application of DOM technology, Using it to write a dynamic page without refreshing is simply easy, and a brother who has done web development should understand how important it is.
First, session monitoring
There are many interfaces in the servlet for session listening, the function is very flexible, the most commonly used is the listening session and attribute. Here to clarify the concept, the servlet in the session monitoring and attribute monitoring meaning there is a difference, session monitoring refers to not what we generally understand to place a session or destroy a session, which is the function of monitoring, Because the syntax for placing sessions in the servlet is Session.setattribute ("Session name", the object to put in). and session listening, listening to the HTTP connection, as long as there is a user connected to the server, even if the connection is a blank JSP page, will also trigger the sessions event, so here is the connection actually refers to the The most appropriate time to count the current number of users online. I don't know if I have made myself clear. The following are the two ways to monitor each.
1, Session Monitoring
First, write a session listener class, which is implemented as the Httpsessionlistener interface, and its function is to calculate how many online users are currently:
/*
* @Author Bromon
*2004-6-12
*/
Package org.bromon.test;
Import javax.servlet.*;
Import javax.servlet.http.*;
public class Sessioncount implements Httpsessionlistener
{
private static int count=0;
public void sessioncreated (httpsessionevent se)
{
count++;
SYSTEM.OUT.PRINTLN ("Session creation:" +new java.util.Date ());
}
public void sessiondestroyed (httpsessionevent se)
{
count--;
SYSTEM.OUT.PRINTLN ("Session Destroy:" +new java.util.Date ());
}
public static int GetCount ()
{
return (count);
}
}
How, is not at a glance? Count is defined as static because it is guaranteed to have only one count for the entire system. If you're not comfortable with it, you can write it as a single case class.
Then declare the listener in Web.xml:
< listener >
< Listener-class >
Org.bromon.test.SessionCount
</listener-class >
</listener >
Write a test page test.jsp to get count:
<%
int Count=org.bromon.test.sessioncount.getcount ();
Out.println (count);
% >
It should be noted that no session action is involved here at all. Restart the app server, try connecting to test.jsp, and you can see that the listener has started working.
2, attribute monitoring
As an in-station message system, it is certain to obtain the ID of all the landers to be able to send messages to each other. This involves attribute monitoring. Suppose we write a user login module, the user will be authenticated after a session, save its relevant information, such as:
check.jsp
<%
String name=request.getparameter ("name");
Name=new String (name.getbytes ("iso8859-1"));
Session.setattribute ("user", name);
% >
The brother who has done JSP should be familiar with this code, the following write a listener to monitor the user login, the ID of all users to a list, the listener implemented as Httpsessionattributelistener interface:
/*
* @Author Bromon
*2004-6-12
*/
Package org.bromon.test;
Import javax.servlet.*;
Import javax.servlet.http.*;
Import java.util.*;
public class Onlinelist implements Httpsessionattributelistener
{
private static List list=new ArrayList ();
public void attributeadded (httpsessionbindingevent se)
{
if ("User". Equals (Se.getname ()))
{
List.add (Se.getvalue ());
}
}
public void attributeremoved (httpsessionbindingevent se)
{
if ("User". Equals (Se.getname ()))
{
List.remove (Se.getvalue ());
}
}
public void attributereplaced (Httpsessionbindingevent se) {}
public static List GetList ()
{
return (list);
}
}
Write a simple JSP to the user list:
<%
Java.util.List list=org.bromon.test.onlinelist.getlist ();
Out.println ("A Total" +list.size () + "The user has Landed:");
for (int i=0;i< lise.size (); i++)
{
Out.println (List.get (i));
}
% >
Perhaps you say, this is what magic, listen to session just, not anxious, look xmlhttp.
Second, XMLHTTP
XMLHTTP a lot of useful, here just say what we need, is no refresh with the server communication, look at this code:
< script language= "JavaScript" >
XML = new ActiveXObject ("Microsoft.XMLHTTP");
var post= "";//construct the data to carry
Xml.open ("Post", "http://localhost:7001/TestWL/index.jsp", false);//Use the POST method to open a connection to the server and communicate asynchronously
Xml.setrequestheader ("Content-length", post.length);
Xml.setrequestheader ("Content-type", "application/x-www-form-urlencoded");
Xml.send (post);//Send data
var res = xml.responsetext;//data returned by the receiving server
document.write (RES);
</script >
Suddenly, the code is to open an HTTP connection, pass the data in the standard HTTP format, and if you like, you can pass it in XML format. Changing the way XML objects are constructed can be compatible with Mozilla and Netscape. Write a poll below, refresh the list of users every once in a while, and of course, do not need to refresh the page:
< HTML >
< head >< Title > Detector </title >
< script language= "JavaScript" >
function Detect ()
{
XML = new ActiveXObject ("Microsoft.XMLHTTP");
var post= "";//construct the data to carry
Xml.open ("Post", "http://localhost:7001/TestWL/index.jsp", false);//Use the POST method to open a connection to the server and communicate asynchronously
Xml.setrequestheader ("Content-length", post.length);
Xml.setrequestheader ("Content-type", "application/x-www-form-urlencoded");
Xml.send (post);//Send data
var res = xml.responsetext;//data returned by the receiving server
List.innertext=res;
SetTimeout ("Detect ()", 5000)//poll once every 5 seconds
}
</script >
< body onload= "detect ()" >
< a id= "list" ></a >
</body >
Such a way of communication data is very small, do not have to transfer the entire page, 5 seconds, the average PC can withstand a larger number of online. Building a probe to monitor online listings and messages is good, even if your client sits in front of the computer and does not touch it, it can ensure that the data is delivered instantly and the page does not jump and refresh.
Session monitoring plus XMLHTTP communication, the development of a more complete station message system is a breeze.