securityutils.getsubject().getprincipal();返回值是null
时间: 2024-04-03 19:36:33 浏览: 90
securityutils.getsubject().getprincipal() 返回 null 的可能原因有很多。其中一种可能是用户没有被正确地认证或者用户没有登录,在这种情况下,主体对象不会包含用户信息。另一种可能是在获取主体对象之前,用户已经退出登录了。你可以检查一下用户是否已经登录,以及登录过程中是否有异常或错误发生。此外,你也可以检查一下代码中是否有其他地方导致了主体对象中的用户信息丢失,比如在处理用户信息时出现异常或错误。
相关问题
手动注入SecurityUtils.getSubject().getPrincipal()
手动注入 `SecurityUtils.getSubject().getPrincipal()` 通常用于在不依赖框架的情况下获取当前登录用户信息。这通常需要手动在代码中注入该信息。
具体实现方式如下:
1. 首先,你需要将用户信息存储到 `SecurityUtils.getSubject().getSession()` 中。可以通过以下代码实现:
```
Subject currentUser = SecurityUtils.getSubject();
Session session = currentUser.getSession();
session.setAttribute("user", user);
```
这里的 `user` 是你自己定义的用户对象。
2. 然后,你需要在需要获取用户信息的地方手动注入 `SecurityUtils.getSubject().getPrincipal()`。例如:
```
Subject currentUser = SecurityUtils.getSubject();
User user = (User) currentUser.getPrincipal();
```
这里的 `User` 是你自己定义的用户对象。
需要注意的是,这种方式获取用户信息需要自己手动管理用户登录状态,包括用户的登录、注销等操作,因此不如使用框架提供的安全认证机制来管理用户登录状态更加方便和安全。
SecurityUtils.getSubject().getPrincipal();
SecurityUtils.getSubject().getPrincipal()是Shiro框架中的一个方法,用于获取当前登录用户的信息。在Shiro框架中,用户信息是在登录时设置的,一般是通过Realm对象的实现类来进行设置。在Realm中,需要实现doGetAuthenticationInfo方法,该方法用于验证用户身份并返回用户信息,返回的用户信息会被设置到Subject对象中,通过调用SecurityUtils.getSubject().getPrincipal()方法可以获取到该信息。同时,需要在ShiroFilterFactoryBean中配置拦截规则,以确保访问的接口需要进行身份验证。
阅读全文