我正试图在嵌入式glassfish的arquillian测试中使用ProgrammaticLogin类来模拟登录。 我的代码如下:
System.setProperty("java.security.auth.login.config","path/login.config")
com.sun.appserv.security.ProgrammaticLogin loginP = new ProgrammaticLogin();
try{
loginP.login("user1","password","fileRealm",true);
}
catch (Exception e){
System.out.println(e.getMessage());
}
我遇到以下异常:
SEVERE: SEC9050: Programmatic login failed
com.sun.enterprise.security.auth.login.common.LoginException: Login failed: Failed file login for user1.
at com.sun.enterprise.security.auth.login.LoginContextDriver.doPasswordLogin(LoginContextDriver.java:394)
at com.sun.enterprise.security.auth.login.LoginContextDriver.login(LoginContextDriver.java:240)
at com.sun.enterprise.security.auth.login.LoginContextDriver.login(LoginContextDriver.java:153)
at com.sun.appserv.security.ProgrammaticLogin$1.run(ProgrammaticLogin.java:174)
at java.security.AccessController.doPrivileged(Native Method)
at com.sun.appserv.security.ProgrammaticLogin.login(ProgrammaticLogin.java:168)
at com.sun.appserv.security.ProgrammaticLogin.login(ProgrammaticLogin.java:239)
at com.sun.appserv.security.ProgrammaticLogin.login(ProgrammaticLogin.java:211)
我添加了包含登录名和密码的属性文件users.properties。
答案 0 :(得分:0)
如果glassfish容器在其自己的进程中运行,则使用System.setProperty()定义的属性不可用。它只在测试中可用,它在不同的过程中运行。也许您应该在部署中添加一个使用@PostConstruct设置属性的bean。