See http://stackoverflow.com/questions/7795012/request-getuserprincipal-got-null.
A way to skip over the problem is to implement Application-Managed Authentication in web application. This means that web-app developer have to implements authentication/authorization.
But not everything is lost! We can reuse the Realm configured within application server to authenticate/authorize application's users.
There are two snippet of code that retrieve the Realm authenticator from ServletContext.
Get Tomcat 7 Realm from ServletContext:
ApplicationContextFacade acf = (ApplicationContextFacade) servletContext;
Field privateField = ApplicationContextFacade.class.getDeclaredField("context");
privateField.setAccessible(true);
ApplicationContext appContext = (ApplicationContext) privateField.get(acf);
Field privateField2 = ApplicationContext.class.getDeclaredField("context");
privateField2.setAccessible(true);
StandardContext stdContext = (StandardContext) privateField2.get(appContext);
realm = stdContext.getRealm();
The realm variable is an instance of org.apache.catalina.Realm, and you can call on this the authenticate method to authenticate and get roles of users:
Principal principal = realm.authenticate(user, password);
if (principal == null)
return null;
GenericPrincipal genericPrincipal = (GenericPrincipal) principal;
return new DemoPrincipal(principal, genericPrincipal.getRoles());
This is the counter part for Jetty 7.5. Be ware that normally Jetty don't allow to reach the container classes from web application class loader, we need to disable this option, see http://docs.codehaus.org/display/JETTY/Classloading.
WebAppContext.Context context = ((org.eclipse.jetty.webapp.WebAppContext.Context) servletContext);
ContextHandler contextHandler = context.getContextHandler();
ConstraintSecurityHandler securityHandler = contextHandler
.getChildHandlerByClass(org.eclipse.jetty.security.ConstraintSecurityHandler.class);
loginService = securityHandler.getLoginService();
UserIdentity login = loginService.login(user, password);
if (login == null)
return null;
Principal principal = login.getUserPrincipal();
Field privateField = DefaultUserIdentity.class.getDeclaredField("_roles");
privateField.setAccessible(true);
String[] roles = (String[]) privateField.get(login);
return new DemoPrincipal(principal, roles);
I use Jetty with maven, this is may configuration:
<plugin>
<groupId>org.mortbay.jetty</groupId>
<artifactId>jetty-maven-plugin</artifactId>
<version>${jetty.version}</version>
<configuration>
<loginServices>
<loginService implementation="org.eclipse.jetty.security.HashLoginService">
<name>MyRealm</name>
<config>${basedir}/src/main/resources/jetty-realm.properties</config>
</loginService>
</loginServices>
<scanIntervalSeconds>1000</scanIntervalSeconds>
<webAppConfig>
<serverClasses>
<serverClass implementation="java.lang.String">
-org.eclipse.jetty.
</serverClass>
</serverClasses>
</webAppConfig>
</configuration>
</plugin>
Nessun commento:
Posta un commento