springboot整合shiro-记住我

本文详细介绍了如何在SpringBoot项目中结合Shiro框架实现‘记住我’功能,包括引入相关依赖、前端页面设置、Controller处理、Shiro配置及RememberMe管理器的配置。通过设置Cookie和加密策略,确保用户登录状态能够被正确记住。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

源码:https://gitee.com/xxxiaowu/springboot-shiro

首先导入依赖

<!--shiro整合springboot的依赖-->
<dependency>
    <groupId>org.apache.shiro</groupId>
    <artifactId>shiro-spring</artifactId>
    <version>1.8.0</version>
</dependency>
<!--thymeleaf-shiro-->
<dependency>
    <groupId>com.github.theborakompanioni</groupId>
    <artifactId>thymeleaf-extras-shiro</artifactId>
    <version>2.1.0</version>
</dependency>

在前端添加记住我的按钮

 <input type="checkbox" name="rememberMe"/>&nbsp;&nbsp;记住我

修改controller,把rememberMe封装到用户登录数据中

 @RequestMapping("/login")
    public String Login(String username, String password, Model model,boolean rememberMe){
        System.out.println("======================>"+rememberMe);
        //获取当前用户
        Subject subject = SecurityUtils.getSubject();
        //封装用户的登录数据
        UsernamePasswordToken token = new UsernamePasswordToken(username,password,rememberMe);

        try {
            //执行登录方法
            subject.login(token);
            return "index";
        } catch (UnknownAccountException e) {
            model.addAttribute("msg","用户名不存在");
            return "login";
        } catch (IncorrectCredentialsException e){
            model.addAttribute("msg","密码错误");
            return "login";
        }
    }

在ShiroConfig里边注入rememberMe


//DefaultWebSecurityManager
    @Bean(name = "securityManager")
    public DefaultWebSecurityManager getDefaultWebSecurityManager(@Qualifier("userRealm") UserRealm userRealm){
        DefaultWebSecurityManager securityManager = new DefaultWebSecurityManager();

        //关联UserRealm
        securityManager.setRealm(userRealm);

        //注入记住我
        securityManager.setRememberMeManager(getCookieRememberMeManager());

        return securityManager;
    }

    /**
     * cookie对象
     * rememberMeCookie()方法是设置Cookie的生成模板,比如Cookie的有效时间
     */
    @Bean
    public SimpleCookie getRememberCookie(){
        //这里边的rememberMe这个参数对应的就是前段记住我input标签的name属性
        SimpleCookie simpleCookie = new SimpleCookie("rememberMe");
        //这个是cookie过期的时间单位是 秒
        simpleCookie.setMaxAge(60*60);
        return simpleCookie;
    }

    /**
     * cookie管理对象
     * rememberMeManager()方法是生成rememberMe管理器,而且要将这个
     * rememberMe管理器设置到securityManage里边
     */
    @Bean
    public CookieRememberMeManager getCookieRememberMeManager(){
        CookieRememberMeManager cookieRememberMeManager = new CookieRememberMeManager();
        cookieRememberMeManager.setCookie(getRememberCookie());

        //cookieRememberMeManager.setCipherKey()
        // 对rememberMe cookie 加密 长度必须是16位,不安然会报异常
        cookieRememberMeManager.setCipherKey("ChengXuYuanYiMei".getBytes());

        return cookieRememberMeManager;
    }

这样就是实现了记住我功能

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值