文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

SSM项目中如何使用拦截器实现登录验证功能

2023-06-28 22:59

关注

小编给大家分享一下SSM项目中如何使用拦截器实现登录验证功能,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

登录接口实现

SSM项目中如何使用拦截器实现登录验证功能

public User queryUser(String UserName, String Password,HttpServletRequest request, HttpServletResponse response) {        User user = userMapper.queryUser(UserName,Password);        if(!StringUtils.isEmpty(user)){            //1.获取session            HttpSession session = request.getSession();            //2.获取sessionid            String sessionId = session.getId();            //3.将sessionid作为key,用户信息user作为value,放入session中            session.setAttribute(sessionId,user);            //4.将sessionId存到cookie中,"JSESSIONID"为自定义的key值            Cookie cookie = new Cookie("JSESSIONID",sessionId);            //5.设置cookie的有效路径            cookie.setPath(request.getContextPath());            //6.将cookie返回给页面            response.addCookie(cookie);        }        return user;    }

代码思路:

用户输入账号密码登录成功后获取用户信息(User)

获取session,得到sessionid(注:每一个session对象都有一个sessionid)

将sessionid作为key,用户信息(User)作为value,放入session中

创建一个Cookie对象,将"JSESSIONID"作为key,sessionId作为value,放入cookie中

设置cookie的有效路径,将cookie返回给页面,此时页面就可以收到key为"JSESSIONID",value为sessionId的cookie信息,如下图。

SSM项目中如何使用拦截器实现登录验证功能

拦截器类代码实现

SSM项目中如何使用拦截器实现登录验证功能

public class Filter extends HandlerInterceptorAdapter {    private static Logger logger = Logger.getLogger(Filter.class);        @Override    public boolean preHandle(HttpServletRequest request,                             HttpServletResponse response, Object handler)throws Exception    {        //1.定义sessionid变量        String sessionid = "";        //2.获取session对象        HttpSession session=request.getSession();        //3.获取页面上所有的cookie        Cookie[] cookies = request.getCookies();        //4.循环寻找名称为"JSESSIONID"的cookie        for(Cookie cookie:cookies){            if(cookie.getName().equals("JSESSIONID")){                sessionid = cookie.getValue();            }        }        //5.根据sessionid获取用户信息        User user = (User) session.getAttribute(sessionid);        if(StringUtils.isEmpty(user)) {            logger.info("用户未登录");            //用户未登录跳转到登录页面            response.sendRedirect("login");            return false;        }        logger.info("用户已登录");        return  true;    }}

代码思路:

自定义一个拦截器类,首先要继承HandlerInterceptorAdapter,并重写preHandle方法,在此方法中编写拦截器的逻辑代码

获取cookies数组,这个数组有浏览器中的所有cookies信息,循环遍历找到name为"JSESSIONID"的cookies,并获取到其value值,这个值就是sessionid

通过sessionid查找user对象,如果能获取对象证明登录过,如果不能获取到对象证明没有登录过

如果登录过就直接访问接口,如果没有登录过就跳转到登录页面进行登录

配置文件实现

SSM项目中如何使用拦截器实现登录验证功能

<!--自定义拦截器-->    <mvc:interceptors>        <mvc:interceptor>            <!--配置要拦截的路径-->            <mvc:mapping path="/**"/>            <!--配置登录接口不被拦截-->            <mvc:exclude-mapping path="/user/login"/>            <!--指定拦截器类路径-->            <bean class="com.lishiqi.Util.Filter"></bean>        </mvc:interceptor>    </mvc:interceptors>

配置含义:

我们使用拦截器肯定要规定拦截哪些接口,首先我们将所有的接口都拦截

然后我们发现问题,此时登录接口也在拦截范围中,所以我们正常调用登录接口之前他也会拦截判断一下用户是否登录过,这个时候用户肯定没有登录过,那么就会又跳转到登录界面,我们再次登录还是跳转到登录页面,一直登录不上,所以我们需要把登录接口配置为不拦截

然后我们指定我们配置好的拦截器类路径,这个时候可以在该类中进行登录验证操作了

此配置文件为spring-mvc.xml配置文件

以上是“SSM项目中如何使用拦截器实现登录验证功能”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网行业资讯频道!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯