security - 检索 Shiro 主体

标签 security jsf shiro

注意:由于随后的研究,这个问题已经完全重组。
我正在尝试从 Shiro 的主题 PrincipalCollection 中检索值.我在集合中添加了两个主体。 UsernameUUID .当我试图记忆这些时,我得到一个 SimplePrincipalCollection大小 = 1,而这又将主体作为 LinkedHashMap大小 = 2。
问题是如何直接检索主体?

最佳答案

为此目的,不需要两个添加多个原则。您可以创建一个包含您需要的所有信息的简单对象 (POJO),并将其用作唯一原则。

public class MyRealm extends JdbcRealm {

...
enter code here


@Override
protected AuthenticationInfo doGetAuthenticationInfo(AuthenticationToken token) throws AuthenticationException {

    SimpleAuthenticationInfo info = null;
    try {
        //GET USER INFO FROM DB etc. here
        MyPrinciple USER_OBJECT = new MyPrinciple();
        USER_OBJECT.setId(UUID);
        USER_OBJECT.setUsername(username);
        info = new SimpleAuthenticationInfo(USER_OBJECT, password.toCharArray(), getName());

    } catch (IOException | SQLException e) {
        logger.error(message, e);
        throw new AuthenticationException(message, e);
    }

    return info;
}

然后,当您需要登录用户的用户信息时,您可以简单地调用 getPrinciple() 并在将其转换为您的用户类 (POJO) 后使用它的 getter 方法:
MyPrinciple LoggedInUser = (MyPrinciple ) SecurityUtils.getSubject().getPrinciple();
long uid = LoggedInUser.getId();
String username = LoggedInUser.getUsername();

关于security - 检索 Shiro 主体,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11580101/

相关文章:

node.js - 服务器日志中对第三方网站的请求

java - Android:替换缺少的安全架构

java - Apache Shiro 用于桌面应用程序?

Spring 安全性与 Apache Shiro

java - JAAS、SAML 和 Realm 之间有什么区别

sql-server - 如何保护 SQL Server 2005 数据库的安全?

css - 更改图形图像中特定部分的颜色

javascript - 如何使用 javascript 保持 primefaces 对话框打开

jsf - 将omnifaces 1.4.1添加到liferay项目时出现Java.lang.ExceptionInInitializerError

java-ee-6 - 注销后 Shiro UnknownSessionException