- 前言
- `springboot` 整合 `shiro` 之实现记住我
- 配置类 `ShiroConfig`
- `login.html` 登录页面
- `controller`
- `UserVO` 类
- 测试
上一篇 文章我们完成了在 thymeleaf 模板引擎中使用 shiro 标签,也就是根据不同的用户身份信息,前端页面来显示不同的页面内容。本篇文章我们来完成在登录页面的记住我的功能
springboot 整合 shiro 之实现记住我项目依然使用 springboot整合shiro 这个项目,稍稍改动即可完成记住我的功能
配置类 ShiroConfig完整的代码如下
@Configuration public class ShiroConfig { @Bean public DefaultWebSecurityManager getDefaultWebSecurityManager(UserRealm userRealm) { DefaultWebSecurityManager defaultWebSecurityManager = new DefaultWebSecurityManager(); defaultWebSecurityManager.setRealm(userRealm); // 实现记住我,所需要的配置 defaultWebSecurityManager.setRememberMeManager(cookieRememberMeManager()); return defaultWebSecurityManager; } @Bean public ShiroDialect getShiroDialect() { return new ShiroDialect(); } @Bean public ShiroFilterFactoryBean shiroFilter(DefaultWebSecurityManager defaultWebSecurityManager) { ShiroFilterFactoryBean shiroFilterFactoryBean = new ShiroFilterFactoryBean(); shiroFilterFactoryBean.setSecurityManager(defaultWebSecurityManager); // 设置登录页面url shiroFilterFactoryBean.setLoginUrl("/user/login"); shiroFilterFactoryBean.setSuccessUrl("/user/index"); shiroFilterFactoryBean.setUnauthorizedUrl("/user/unauthorized"); // 注意此处使用的是linkedHashMap是有顺序的,shiro会按从上到下的顺序匹配验证,匹配了就不再继续验证 MapUserVO 类filterChainDefinitionMap = new linkedHashMap<>(); filterChainDefinitionMap.put("/layer @PostMapping(path = "/doLogin") @ResponseBody public ResultMap doLogin(@NotNull @Valid UserVO userVO, @NotNull BindingResult bindingResult) { // ------参数校验------ if (bindingResult.hasErrors()) { String message = Objects.requireNonNull(bindingResult.getFieldError()).getDefaultMessage(); log.info("校验的message信息为:" + message); return new ResultMap().fail().message(message); } // 将用户名,密码交给shiro UsernamePasswordToken token = new UsernamePasswordToken(userVO.getUsername(), userVO.getPassword(), userVO.getRememberMe()); String msg; try { // shiro帮我们匹配密码什么的,我们只需要把东西传给它,它会根据我们在UserRealm里认证方法设置的来验证 Subject subject = SecurityUtils.getSubject(); subject.login(token); return new ResultMap().success().action("/user/index"); } catch (AuthenticationException e) { if (e instanceof IncorrectCredentialsException) { msg = "密码错误"; } else if (e instanceof LockedAccountException) { msg = "用户被禁用"; } else if (e instanceof UnknownAccountException) { msg = "用户不存在"; } else { msg = "用户认证失败"; } } return new ResultMap().error().message(msg); } @GetMapping(path = "/logout") public String logout(HttpServletResponse response) { Subject subject = SecurityUtils.getSubject(); if (subject.isAuthenticated()) { subject.logout(); cookie cookie = new cookie("rememberMe", null); cookie.setMaxAge(0); response.addcookie(cookie); } return "login"; } }
public class UserVO implements Serializable { @NotBlank(message = "账号不能为空") private String username; @NotEmpty(message = "密码不能为空") private String password; private Boolean rememberMe; // 省略set/get方法 }测试
我们以账号 jack 为例进行登录,如下
进入首页页面如下,再次查看 cookies 数据
我们这时关闭这个首页页面,在浏览器地址栏输入 http://127.0.0.1:8080/user/index 再次进入首页页面,会发现如上图一样,可以顺利访问,说明我们的记住我功能已经实现。这时,可以再次在浏览器地址栏输入 http://127.0.0.1:8080/user/add,进入 add.html 页面,如下
在 cookies 的有效期内,当你关闭浏览器之后,再次进入 add.html 页面时,无需登录直接就可以访问了,说明记住我功能已经实现了。在浏览器地址栏输入 http://127.0.0.1:8080/user/update,进入 update.html 页面,如下
说明账号 jack 没有权限访问 update.html 页面,可以看控制台 sql 日志
源码:springboot-shiro
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)