Java.lang.SecurityException: Unable to locate a login configuration

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 ?

[color=darkblue] Sei que o tópico é antigo, mas estou tendo o mesmo problema, como você conseguiu resolver ?[/color]

03/02/2011 10:41:17 org.apache.catalina.realm.JAASRealm authenticate
SEVERE: Cannot find message associated with key jaasRealm.unexpectedError
java.lang.SecurityException: Unable to locate a login configuration
	at com.sun.security.auth.login.ConfigFile.&lt;init&gt;(ConfigFile.java:93)
	at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
	at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:39)
	at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:27)
	at java.lang.reflect.Constructor.newInstance(Constructor.java:513)
	at java.lang.Class.newInstance0(Class.java:355)
	at java.lang.Class.newInstance(Class.java:308)
	at javax.security.auth.login.Configuration$3.run(Configuration.java:246)
	at java.security.AccessController.doPrivileged(Native Method)
	at javax.security.auth.login.Configuration.getConfiguration(Configuration.java:241)
	at javax.security.auth.login.LoginContext$1.run(LoginContext.java:237)
	at java.security.AccessController.doPrivileged(Native Method)
	at javax.security.auth.login.LoginContext.init(LoginContext.java:234)
	at javax.security.auth.login.LoginContext.&lt;init&gt;(LoginContext.java:403)
	at org.apache.catalina.realm.JAASRealm.authenticate(JAASRealm.java:394)
	at org.apache.catalina.realm.JAASRealm.authenticate(JAASRealm.java:335)
	at org.apache.catalina.authenticator.FormAuthenticator.authenticate(FormAuthenticator.java:259)
	at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:454)
	at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:127)
	at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)
	at org.apache.catalina.authenticator.SingleSignOn.invoke(SingleSignOn.java:394)
	at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
	at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:298)
	at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:857)
	at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:588)
	at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:489)
	at java.lang.Thread.run(Thread.java:619)
Caused by: java.io.IOException: Unable to locate a login configuration
	at com.sun.security.auth.login.ConfigFile.init(ConfigFile.java:250)
	at com.sun.security.auth.login.ConfigFile.&lt;init&gt;(ConfigFile.java:91)
	... 26 more

[color=darkblue] Desde já agradeço ![/color]

[color=darkblue]Resolvi colocando a seguinte String no run configurations, obrigado : [/color]

 -Djava.security.auth.login.config="C:\java\apache-tomcat-6.0.28\conf\jaas.config"

To pegando o mesmo erro.

SEVERE: Unexpected error
java.lang.SecurityException: Unable to locate a login configuration

Atualizei o java.security com login.config.url.1=file:D:/apache-tomcat-6.0.37-windows-x64/conf/jaas.config
Atualizei o server.xml com o Realm

Inicio a aplicação, e na tela de login me deparo com este erro.
Ja conferi a permissão de acesso ao BD, está ok.
Tenho um servidor linux, que aponta para o mesmo banco, e lá, a aplicação funciona.

Este erro ocorre quando tento iniciar a aplicação a partir do Eclipse.

Tentei jogar esta linha [set JAVA_OPTS=-Djava.security.auth.login.config="%CATALINA_HOME%\conf\login.config"] no catalina.bat e nada.

Alguém pode me ajudar, por favor?

Att.,
Eduardo.

Tive o mesmo problema e gastei dias para resolver… Mas ao ler este tópico percebi o que estava ocorrendo:

Tenho mais de um java instalado. E estava iniciando o TOMCAT via Eclipse. O que acontece é o seguinte:
uso o java 1.4.2 no projeto, mas para rodar o Eclipse Kepler, pelo menos o java 6 deve estar setado como JAVA_HOME. Então o Eclipse buscava o o arquivo java.security do diretório de instalação do JDK de dentro do java 6 e eu tinha alterado o campo dentro do java 1.4.2.

[code]
#
# 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  [/code]

[size=18]Resolvi de duas formas[/size]

1- Colocando esta String no parametro da JVM do run configurations do Eclipse como disse o Metaleiro:
[color=blue]-Djava.security.auth.login.config=“C:\java\apache-tomcat-6.0.28\conf\jaas.config” [/color]

2- Setando o login.config.url.1 de dentro da pasta do java 6 (…jre6/lib/security/java.security).

Espero ter ajudado!