Pessoal, implementei uma autenticação com JAAS.
Utilizo essa autenticação já faz mas de ano, mas começou a dar um problema e não consegui resolver.
Configurei o TOMCAT para iniciar pelo Eclipse.
Quando starto o TOMCAT, sobe normalmente, mas quando informo os dados e submeto para realizar a autenticação é lançado a exception abaixo.
15/07/2008 08:40:44 org.apache.catalina.realm.JAASRealm authenticate
SEVERE: Unexpected error
java.lang.SecurityException: Unable to locate a login configuration
at com.sun.security.auth.login.ConfigFile.<init>(Unknown Source)
at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
at sun.reflect.NativeConstructorAccessorImpl.newInstance(Unknown Source)
at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(Unknown Source)
at java.lang.reflect.Constructor.newInstance(Unknown Source)
at java.lang.Class.newInstance0(Unknown Source)
at java.lang.Class.newInstance(Unknown Source)
at javax.security.auth.login.Configuration$3.run(Unknown Source)
at java.security.AccessController.doPrivileged(Native Method)
at javax.security.auth.login.Configuration.getConfiguration(Unknown Source)
at javax.security.auth.login.LoginContext$1.run(Unknown Source)
at java.security.AccessController.doPrivileged(Native Method)
at javax.security.auth.login.LoginContext.init(Unknown Source)
at javax.security.auth.login.LoginContext.<init>(Unknown Source)
at org.apache.catalina.realm.JAASRealm.authenticate(JAASRealm.java:344)
at org.apache.catalina.authenticator.FormAuthenticator.authenticate(FormAuthenticator.java:258)
at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:417)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:127)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:117)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:108)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:151)
at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:874)
at org.apache.coyote.http11.Http11BaseProtocol$Http11ConnectionHandler.processConnection(Http11BaseProtocol.java:665)
at org.apache.tomcat.util.net.PoolTcpEndpoint.processSocket(PoolTcpEndpoint.java:528)
at org.apache.tomcat.util.net.LeaderFollowerWorkerThread.runIt(LeaderFollowerWorkerThread.java:81)
at org.apache.tomcat.util.threads.ThreadPool$ControlRunnable.run(ThreadPool.java:689)
at java.lang.Thread.run(Unknown Source)
Caused by: java.io.IOException: Unable to locate a login configuration
at com.sun.security.auth.login.ConfigFile.init(Unknown Source)
... 27 more
Para essa autenticação é necessário realizar as seguintes configurações:
1 - No arquivo java.security do diretório de instalação do JDK (C:\Desenvolvimento\jdk1.5.0_11\jre\lib\security), adiciono a seguinte linha.
#
# Default login configuration file
#
# login.config.url.1=file:${user.home}/.java.login.config
login.config.url.1=file:E:/Java/apache-tomcat-5.5.25/conf/jaas.config
2 - No arquivo server.xml do diretório de instalação do TOMCAT (C:\Desenvolvimento\apache-tomcat-5.5.25\conf) adiciono o JAASRealm.
<Realm className="org.apache.catalina.realm.JAASRealm"
appName="unicLogin"
userClassNames="br.com.unic.solicitacao.autenticacao.login.security.principal.UsuarioPrincipal"
roleClassNames="br.com.unic.solicitacao.autenticacao.login.security.principal.RolePrincipal"
debug="99"
useContextClassLoader="false"/>
3 - Criar o arquivo de configuração jaas.config no diretório de instalação do TOMCAT (C:\Desenvolvimento\apache-tomcat-5.5.25\conf).
unicLogin {
br.com.unic.solicitacao.autenticacao.login.security.module.UnicLoginModule required
debug="true";
};
Sempre utilizei essa autenticação, mas começou a dar esse problema, estou a dois dias fazendo diversos testes mas não funciona.
Alguém tem uma diga do que pode estar acontecendo ?