Monday, July 9, 2018

HttpSessionActivationListener

Methods of HttpSessionActivationListener interface
  1. public void sessionWillPassivate(HttpSessionEvent se): Notification that the session is about to be passivated.
  2. public void sessionDidActivate(HttpSessionEvent se): Notification that the session has just been activated.

HttpSessionAttributeListener

Methods of HttpSessionAttributeListener interface
  1. void attributeAdded(HttpSessionBindingEvent event): Receives notification that an attribute has been added to a session.
  2.  void attributeRemoved(HttpSessionBindingEvent event): Receives notification that an attribute has been removed from a session.
  3. void attributeReplaced(HttpSessionBindingEvent event): Receives notification that an attribute has been replaced in a session.

HttpSessionBindingEvent and HttpSessionBindingListener


Constructor of  HttpSessionBindingEvent class
  1. public HttpSessionBindingEvent(HttpSession session, java.lang.String name)
  2. public HttpSessionBindingEvent(HttpSession session, java.lang.String name, java.lang.Object value): Constructs an event that notifies an object that it has been bound to or unbound from a session
Methods of  HttpSessionBindingEvent class
  1. public HttpSession getSession(): Return the session that changed.
  2. public java.lang.String getName(): Returns the name with which the attribute is bound to or unbound from the session.
  3. public java.lang.Object getValue(): Returns the value of the attribute that has been added, removed or replaced. If the attribute was added (or bound), this is the value of the attribute. If the attribute was removed (or unbound), this is the value of the removed attribute. If the attribute was replaced, this is the old value of the attribute.
Methods of  HttpSessionBindingListener interface
  1. void valueBound(HttpSessionBindingEvent event): Notifies the object that it is being bound to a session and identifies the session.
  2. void valueUnbound(HttpSessionBindingEvent event): Notifies the object that it is being unbound from a session and identifies the session.

HttpSessionEvent and HttpSessionListener


  • The HttpSessionEvent is notified when session object is changed. The corresponding Listener interface for this event is HttpSessionListener.
  • We can perform some operations at this event such as counting total and current logged-in users, maintaing a log of user details such as login time, logout time etc.
Constructor of HttpSessionEvent class
  1. HttpSessionEvent(HttpSession source): Construct a session event from the given source.
Method of HttpSessionEvent class
  1. public HttpSession getSession(): Return the session that changed
Methods of HttpSessionListener interface
  1. public void sessionCreated(HttpSessionEvent e): is invoked when session object is created.
  2. public void sessionDestroyed(ServletContextEvent e): is invoked when session is invalidated. 
In this example, are counting the total and current logged-in users. For this purpose, we have created three files:

    Login.html: to get input from the user.
    MyListener.java: A listener class that counts total and current logged-in users and stores this    
    information in ServletContext object as an attribute.
    First.java: A Servlet class that creates session and prints the total and current logged-in users.
    Logout.java: A Servlet class that invalidates session.

web.xml

<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.5"
    xmlns="http://java.sun.com/xml/ns/javaee"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
    http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">
 
  <listener>
  <listener-class>CountUserListener</listener-class>
  </listener>
 
  <servlet>
     <servlet-name>First</servlet-name>
    <servlet-class>First</servlet-class>
  </servlet>
  <servlet>
      <servlet-name>LogoutServlet</servlet-name>
    <servlet-class>LogoutServlet</servlet-class>
  </servlet>

  <servlet-mapping>
    <servlet-name>First</servlet-name>
    <url-pattern>/servlet1</url-pattern>
  </servlet-mapping>

  <servlet-mapping>
    <servlet-name>LogoutServlet</servlet-name>
    <url-pattern>/logout</url-pattern>
  </servlet-mapping>
 
</web-app>


CountUserListener.java

import javax.servlet.ServletContext;
import javax.servlet.http.HttpSessionEvent;
import javax.servlet.http.HttpSessionListener;

public class CountUserListener implements HttpSessionListener{
    ServletContext ctx=null;
    static int total=0,current=0;
   
    public void sessionCreated(HttpSessionEvent e) {
    total++;
    current++;
   
    ctx=e.getSession().getServletContext();
    ctx.setAttribute("totalusers", total);
    ctx.setAttribute("currentusers", current);
   
    }

    public void sessionDestroyed(HttpSessionEvent e) {
            current--;
            ctx.setAttribute("currentusers",current);
    }

}

Login.html


<form action="servlet1">
Name:<input type="text" name="username"><br>
Password:<input type="password" name="userpass"><br>

<input type="submit" value="login"/>
</form>


First .java

import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.ServletContext;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;

public class First extends HttpServlet {
public void doGet(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {

        response.setContentType("text/html");
        PrintWriter out = response.getWriter();
   
        String n=request.getParameter("username");
        out.print("Welcome "+n);
      
        HttpSession session=request.getSession();
        session.setAttribute("uname",n);
      
        ServletContext ctx=getServletContext();
        int t=(Integer)ctx.getAttribute("totalusers");
        int c=(Integer)ctx.getAttribute("currentusers");
        out.print("<br>total users= "+t);
        out.print("<br>current users= "+c);
        out.print("<br><a href='logout'>logout</a>");
        out.close();
    }

}


LogoutServlet .java

import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
 

public class LogoutServlet extends HttpServlet {
    public void doGet(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {

        response.setContentType("text/html");
        PrintWriter out = response.getWriter();
   
        HttpSession session=request.getSession(false);
        session.invalidate();
      
        out.print("You are successfully logged out");
        out.close();
    }

}

ServletContextAttributeEvent and ServletContextAttributeListener

Constructor of ServletContextAttributeEvent Class
  1. public ServletContextAttributeEvent(ServletContext source, java.lang.String name,java.lang.Object value): Construct a ServletContextAttributeEvent from the given context for the given attribute name and attribute value.
Methods of ServletContextAttributeEvent Class
  1. public java.lang.String getName(): Return the name of the attribute that changed on the ServletContext.
  2. public java.lang.Object getValue(): Returns the value of the attribute that has been added, removed, or replaced.
Methods of  ServletContextAttributeListener interface
  1. void attributeAdded(ServletContextAttributeEvent event): Receives notification that an attribute has been added to the ServletContext.
  2. void attributeRemoved(ServletContextAttributeEvent event): Receives notification that an attribute has been removed from the ServletContext.
  3. void attributeReplaced(ServletContextAttributeEvent event): Receives notification that an attribute has been replaced from the ServletContext.

ServletRequestAttributeEvent and ServletRequestAttributeListener

Constructor of ServletRequestAttributeEvent 
  1. public ServletRequestAttributeEvent(ServletContext sc, ServletRequest request, java.lang.String name, java.lang.Object value)

Parameters:
    sc - the ServletContext that is sending the event.
    request - the ServletRequest that is sending the event.
    name - the name of the request attribute.
    value - the value of the request attribute.

Methods of ServletRequestAttributeEvent
  1. public java.lang.String getName(): Return the name of the attribute that changed on the ServletRequest. 
  2. public java.lang.Object getValue(): Returns the value of the attribute that has been added, removed or replaced.
Methods of ServletRequestAttributeListener
  1. void attributeAdded(ServletRequestAttributeEvent srae): Receives notification that an attribute has been added to the ServletRequest.
  2. void attributeRemoved(ServletRequestAttributeEvent srae): Receives notification that an attribute has been removed from the ServletRequest.
  3. void attributeReplaced(ServletRequestAttributeEvent srae): Receives notification that an attribute has been replaced on the ServletRequest.

ServletContextEvent and ServletContextListener


  • The ServletContextEvent is notified when web application is deployed on the server.
  • If you want to perform some action at the time of deploying the web application such as creating database connection, creating all the tables of the project etc, you need to implement ServletContextListener interface and provide the implementation of its methods. 

Constructor of ServletContextEvent class
  1. ServletContextEvent(ServletContext source): Construct a ServletRequestEvent for the given ServletContext and ServletRequest.

Methods of ServletContextEvent class
  1.  public ServletContext getServletContext(): Returns the instance of ServletContext.
Methods of ServletContextListener interface
  1. public void contextInitialized(ServletContextEvent e): is invoked when application is deployed on the server.
  2. public void contextDestroyed(ServletContextEvent e): is invoked when application is undeployed from the server.

ServletRequestEvent and ServletRequestListener


Constructor of ServletRequestEvent Class
  1. public ServletRequestEvent(ServletContext sc, ServletRequest request) 
Methods of ServletRequestEvent Class
  1. public ServletRequest getServletRequest(): Returns the ServletRequest that is changing. 
  2. public ServletContext getServletContext(): Returns the ServletContext of this web application.
 Methods of ServletRequestListener
  1. void requestDestroyed(ServletRequestEvent sre): Receives notification that a ServletRequest is about to go out of scope of the web application.
  2. void requestInitialized(ServletRequestEvent sre): Receives notification that a ServletRequest is about to come into scope of the web application.


Event and Listener in Servlet

Servlet Listener is used for listening to events in a web containers, such as when you create a session, or place an attribute in an session or if you passivate and activate in another container, to subscribe to these events you can configure listener in web.xml.

Event classes
  1. ServletRequestEvent
  2. ServletContextEvent
  3. ServletRequestAttributeEvent
  4. ServletContextAttributeEvent
  5. HttpSessionEvent
  6. HttpSessionBindingEvent
Event interfaces
  1. ServletRequestListener
  2. ServletContextListener
  3. ServletRequestAttributeListener
  4. ServletContextAttributeListener
  5. HttpSessionListener
  6. HttpSessionBindingListener
  7. HttpSessionAttributeListener
  8. HttpSessionActivationListener