我試圖JBoss容器內的不同身份驗證下通過這樣的(剝離異常處理)的用戶登錄編程方式運行代碼:登錄用戶通過編程JAAS
登錄的newuser
LoginContext ctx = ctx =
new LoginContext("MyLoginSchema",
new UsernamePasswordCallbackHandler("newuser", "")
);
ctx.login();
Subject.doAs(ctx.getSubject(), new PrivilegedAction<T>() {
@Override
public T run() {
Subject.getSubject(AccessController.getContext());
InitialContext ic = new InitialContext();
EJBContext sctxLookup = (EJBContext) ic.lookup("java:comp/EJBContext");
Principal principal = sctxLookup.getCallerPrincipal();
}
});
作品(電話LoginModule
已成功),但Subject.doAs()
未將新主題與EJBContext
關聯。 run()
中的代碼 - 方法仍然從EJBContext
中提取舊用戶的主體。
我測試獲取登錄的用戶,但另一種方法相同的行爲在這裏:
Subject caller = (Subject) PolicyContext.getContext("javax.security.auth.Subject.container");
任何想法?
是的!這纔是重點。我加了ClientLoginModule,它工作。 – roehrijn