Search code examples
javajsfauthenticationmanaged-beanj-security-check

How can I get the logged-in user's username using JDBCRealm?


I'm running Glassfish 3.0 and I'm implementing JDBCRealm for login authentication. The username and roles are saved in a table called usertable. The authentication is working as expected.

But the problem is now when the user logs in, how can I retrieve the username of the logged in user in the application?

PS: I'm implementing JSF page and Managed Bean


Solution

  • In JSF, you can retrieve the current Principal associated with the request and hence, the current session, using the ExternalContext object, which can be retrieved from the FacesContext. The Principal associated with the request is accessible from the ExternalContext using the getUserPrincipal() method:

    FacesContext.getCurrentInstance().getExternalContext().getUserPrincipal();
    

    The above invocation can be done in a JSF managed bean. You can invoke the getName() method on the Principal object to retrieve the name of the user as a String.

    Note that, it possible for you to obtain a Principal instance that references the Anonymous user, if you are retrieving the Principal before authentication, or if the authentication scheme does not protect the entire site.