I get the username of the connected user (using j_security_check) this way, through a managed bean:
......
username = FacesContext.getCurrentInstance().getExternalContext().getUserPrincipal().getName();
And then display it in a jsf page this way : #{userBean.username}
But I figured no way to get the number of connected users and get their role.
In other words, I want to display besides the username, the user role and the number of connected users.
How can I achieve this!?
Thanks in advance for your help!
EDIT: I can now get the Role of the connected user, using a namedquery in a managed bean :
public Users getUserRole(){
try {
Users auser = (Users)
em.createNamedQuery("Users.findByUsername").
setParameter("username", getRemoteUser()).getSingleResult();
return auser;
} catch (NoResultException nre) {
JsfUtil.addErrorMessage(nre, "getUserRole Error");
return null;
}
}
and in the xhtml page:
<h:outputLabel for="rolefacet" value="Role: "/>
<h:outputFormat id="rolefacet" value="#{UserBean.userRole.ugroup}" />
while ugroup is the role name in the Users entity class.
EDIT: One solution that still does not work for me is to add a HttpSessionListener to my web.xml:
package beans;
/**
*
* @author med81
*/
import java.io.Serializable;
import javax.servlet.http.HttpSessionEvent;
import javax.servlet.http.HttpSessionListener;
import javax.servlet.http.HttpSession;
import java.util.List;
import java.util.ArrayList;
import javax.faces.context.FacesContext;
public class SessionCounter implements Serializable, HttpSessionListener {
private List sessions = new ArrayList();
Object s = FacesContext.getCurrentInstance().getExternalContext().getSession(false);
public Object getS() {
return s;
}
public void setS(Object s) {
this.s = s;
}
public SessionCounter() {
}
public void sessionCreated(HttpSessionEvent event) {
HttpSession session = event.getSession();
sessions.add(session.getId());
session.setAttribute("counter", this);
}
public void sessionDestroyed(HttpSessionEvent event) {
HttpSession session = event.getSession();
sessions.remove(session.getId());
session.setAttribute("counter", this);
}
/**
*
* @return size of the session list
*/
public int getActiveSessionNumber() {
return sessions.size();
}
}
Here's a basic kickoff example how you could do it when you're on Servlet 3.0 and thus are able to utilize programmatic login by the new
HttpServletRequest#login()
API.The login form:
login.xhtml
The user manager bean:
com.example.UserManager
The logout (and session invalidate) listener:
com.example.LogoutListener
(Do not do this in
logout()
method! It's the session invalidation which triggers this, the session invalidation will take place whenlogout()
is called OR when session has expired)In any logged-in view you can obtain the current user and the login count as follows:
I'll assume that you mean to get the number of logged-in users.
Basically, you need to have an applicationwide
Set<User>
with all logged-in users and add theUser
to it when it logs in and remove theUser
when it logs out or when its session is destroyed. Here's an example which uses an application scoped managed beanIf you were using Java EE 6 it would have been easy to replace
j_security_check
by a managed bean method which utilizes the new Servlet 3.0HttpServletRequest#login()
and simultaneously adds theUser
to theSet<User>
of the injectedLoginManager
bean. But on Java EE 5 there is no trivial way to hook on it. You would need to check every request for the logged-in user. Best to achieve this is to put theUser
object in the session whenever there's anUserPrincipal
. You can do this using a filter which does roughly the following job indoFilter()
method.Finally, to remove the user from the logins, best is to hook on
HttpSessionListener#sessionDestroyed()
, assuming that you're invalidating the session on logout. This will also be called when the session expires.