系统中使用shrio登录后获取当前登陆的用户很简单 只需要一句代码 这是在session中获取当前登陆的用户信息。
Parent parent = (Parent) SecurityUtils.getSubject().getPrincipal();
这段代码在系统中任何地方都可以使用,但是由于是在session中获取的,如果说用户修改了用户的个人信息,会发现明明数据库已经修改成功了,但是这里的数据还没有变。而我们需要做的是在更新数据库操作的时候也更新当前的用户信息
public Result updateParent(Parent parent) {
parentMapper.updateByPrimaryKeySelective(parent);
//修改登陆的家长信息
Parent parentLogin = (Parent) SecurityUtils.getSubject().getPrincipal();
parentLogin.setName(parent.getName());
parentLogin.setEmail(parent.getEmail());
parentLogin.setGender(parent.getGender());
return Result.ok();
}
如果说想在注册成功或者修改密码成功的时候直接登陆当前已经注册的账号 只需要将当前的账号密码加进去即可(我这里没有使用密码加密,所以直接用明文密码登陆,注意密码要加toCharArray)
UsernamePasswordToken token = new UsernamePasswordToken();
token.setUsername(phone);
token.setPassword(password.toCharArray());
SecurityUtils.getSubject().login(token);
如果是想在jsp 等页面上获取用户信息 需要在jsp头部添加shiro标签
<%@ taglib prefix="shiro" uri="http://shiro.apache.org/tags" %>
使用时
<shiro:principal property="name"/>
就可以达到这样的效果