| By Emanuele Tatti | Article Rating: |
|
| February 6, 2008 04:15 AM EST | Reads: |
26,037 |
Usually, in a rich internet application (RIA), a user with a registered account can do two different logins from two different workstations and can maintain two concurrent sessions opened. In some applications we want to limit the users to one session per account, so we have to take countermeasures.
A simple method to check if a user is logged is to set a property in the current HttpSession; in this example in our login function we set
session.setAttribute("username", username);
If there is no username attribute, we will return an error to the user.
When someone starts a session with his account we have to check if there is already a session opened with that account. We can use an HashMap using the username as key and the session as value; obviously we have to use the same hashmap across multiple logins. A very fast and simple solution is to create a singleton that exposes operations on our hashmap:
public class MySessionManager {
public boolean exist(String username) {
if(hashMap.containsKey(username)) {
return true;
}
return false;
}
public boolean addSession(HttpSession session) {
if(hashMap.containsKey(session.getAttribute("username"))) {
return false;
}
hashMap.put((YouthruCorpPrincipal)session.
getAttribute("username"), session);
return true;
}
public HttpSession getSession(String username) {
return hashMap.get(username);
}
public boolean removeSession(String username) {
if(!hashMap.containsKey(username)) {
return false;
}
hashMap.remove(username);
return true;
}
private static MySessionManager instance;
public static MySessionManager getInstance() {
if(instance == null)
instance = new MySessionManager();
return instance;
}
public MySessionManager() {
hashMap = new HashMap();
}
}
In our login function we have to check the existence of a previously created session with the same username, in that case we can logout the user associated with that session:
if(MySessionManager.getInstance.exist(username)) {
logout(MySessionManager.getInstance.getSession(username));
MySessionManager.getInstance.removeSession(username);
}
In this case the logout function takes as argument a session and log out from our application the user associated with that session, then we can do our login routine and at add the current session to the hashmap.
In this example we are checking only for sessions with a username attached, if we want to do some operation every time a session is created/destroyed, we can implement the HttpSessionListener interface:
Classes that implement this interface will be notified of session creation and destruction using the respective functions:
void sessionCreated(HttpSessionEvent se)
void sessionDestroyed(HttpSessionEvent se)
To receive notification events, the implementation class must be configured in the deployment descriptor for the web application; for example:
<web-app version="2.4" xmlns="http://java.sun.com/xml/ns/j2ee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/
j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">
<listener>
<listener-class>
myapp.security.MySessionListener
</listener-class>
</listener>
</web-app>
Published February 6, 2008 Reads 26,037
Copyright © 2008 SYS-CON Media, Inc. — All Rights Reserved.
Syndicated stories and blog feeds, all rights reserved by the author.
More Stories By Emanuele Tatti
Emanuele Tatti is a software engineer at Comtaste, a consulting company and solution provider for Rich Internet Applications (RIA) based in Rome, Italy, and operating internationally (www.comtaste.com/en). His areas of expertise are Flex, Livecycle Data Services, BlazeDS and Java for building enterprise applications. He has been involved in several projects especially related to the financial field and is also chief engineer for YouThruBiz, an innovative enterprise-class rich internet application which allows companies and recruiters to select human resources through multimedia job interviews and e-resumes.
His posts can be found at blog.comtaste.com
- Cloud People: A Who's Who of Cloud Computing
- New Relic Q1 2013 Blazes Past Growth Targets and Reaches 40,000 Active Customer Accounts
- Cloud Expo New York: Using APIs for Better Business Partnerships
- Research and Markets: Crystal Oscillator Market: Global Forecast & Analysis - A Market Research Report Segmented by General Circuitry, By Applications, By Technology, By Mounting Scheme & Geography (2013-2018)
- Don’t forget to register for FOSE 2013
- Component Models in Java | Part 2
- Synchronoss Technologies to Present at Upcoming Conferences
- API Management Start-Up Gets Funding
- Interop Las Vegas Previews News Announcements from over 60 Exhibitors & Sponsors
- Verizon to Go into the Cloud Storage Biz
- How to Stop Worrying and Love Your Cloud
- ITC Clears Apple of Patent Infringement
- Cloud People: A Who's Who of Cloud Computing
- New Relic Q1 2013 Blazes Past Growth Targets and Reaches 40,000 Active Customer Accounts
- GDS International Confirms Unprecedented Delegation for Upcoming Next Generation Telecoms Europe Summit in May
- AWS Going into a New Line of Work
- Cloud Expo New York: Using APIs for Better Business Partnerships
- Research and Markets: Crystal Oscillator Market: Global Forecast & Analysis - A Market Research Report Segmented by General Circuitry, By Applications, By Technology, By Mounting Scheme & Geography (2013-2018)
- Google Compute enters the IaaS market
- Agile Solutions for Cloud, Big Data, Mobility Services
- SolarWinds to Announce First Quarter 2013 Financial Results on Tuesday, April 30 and Present at Upcoming Investor Conferences
- Don’t forget to register for FOSE 2013
- Apple’s Key Rubber-Band Patent Found Invalid Again
- How to Re-imagine Your Business for a Mobile World
- Where Are RIA Technologies Headed in 2008?
- Should RIM BlackBerries Be Rented?
- Has the Technology Bounceback Begun?
- Trump's Apprentice Runner-Up Rebecca Jarvis Has $150,000 Job Offer From SYS-CON Media
- "Mobile Web 2.0" – How Web 2.0 Impacts Mobility & Digital Convergence
- Ringback Tones
- Microsoft and Sprint Collaborate on Mobile Search
- Mobile Music Gets Boost From New W600 "Walkman Phone"
- i-Technology Blog: Zero-Cost Telephony, the 6-Ton Elephant in the Telco Room
- Dolphin Announces Open API With Over 50 Add-ons Including Dropbox and Wikipedia
- Java Edition of Windows Live Messenger for Mobile Launched
- Alcatel + Microsoft = Internet TV Over IP, a.k.a. "IPTV," Coming Soon To a PC or TV Near You




















