cookie+拦截器实现不同角色对应不同的登录页()

  本篇文章为你整理了cookie+拦截器实现不同角色对应不同的登录页()的详细内容,包含有 cookie+拦截器实现不同角色对应不同的登录页,希望能帮助你了解 cookie+拦截器实现不同角色对应不同的登录页。

  问题描述:由于业务需求,系统中有 A角色需要看A登录页、B角色需要看B登录页面。注意是同一个系统哦。现在问题来了,有同学可能会回答了,这样就太简单了,A角色直接访问A登录页,B角色直接访问B登录页就完事了,那么的地址肯定不是一样的,但是退出的时候怎么办,页面怎么跳转呢?我们下面分析问题!

  页面退出分为两种情况!

  1.用户直接点击退出按钮,主动退出。

  2.session失效,被动退出。

  问题解决方案

  1.主动退出。

  我认为有两种方案。

  A:角色在系统启动时绑定对应登录地址,当用户登录系统后,我们可以获取用户角色,退出时,通过角色可以获取到对应的登录地址。

  B:另外一种情况,我们假设A角色就是通过A登录页进入的,B角色就是通过B登录页进入的,这样我们在用户登录成功后,可以在session里面直接保存对应的登录页地址。退出时,通过获取session的地址就可以退到指定的页面。我个人推荐这种方案。

  2.被动退出。

  session失效,此时是获取不到用户信息的,如果获取不到用户信息,想自动定位到指定页面就比较麻烦,现场B角色用户说我一会儿没操作,怎么会跳到A登录页,会接到投诉电话。后来我们用了cookie技术,每次用户登录成功后,将cookie保存到用户浏览器,用户浏览器写入角色信息,这样当用户重新刷新页面时,用过拦截器技术,就可以自动定位页面。(不要总想着用户会输入你给的网址,他们不会记,也记不住),我们来看看具体实现代码。

  

  cookie写入部分代码

  
private void addUserAccCookie(HttpServletResponse response,TBaseDataUserInfoEntity userInfoEntity){

   Cookie cookie = new Cookie(UserInfoConstants.PRE_USER_ACC, String.valueOf(userInfoEntity.getOrgId()));

   // Cookie描述

   cookie.setComment("shiro acc");

   //秒为单位(3个小时)

   cookie.setMaxAge(3*60*60);

   cookie.setPath("/");

   response.setCharacterEncoding("UTF-8");

   response.setContentType("text/html;charset=UTF-8");

   response.addCookie(cookie);

   }

 

 

  

  

  这段代码需要在拦截器里面判断。给大家参考下。

  好了,今天我们就介绍到这里吧,有不明白的可以下面浏览哦。喜欢的请点赞加关注哦。我是叫练【公众号】,边叫边练。

  

  

  以上就是cookie+拦截器实现不同角色对应不同的登录页()的详细内容,想要了解更多 cookie+拦截器实现不同角色对应不同的登录页的内容,请持续关注盛行IT软件开发工作室。

郑重声明:本文由网友发布,不代表盛行IT的观点,版权归原作者所有,仅为传播更多信息之目的,如有侵权请联系,我们将第一时间修改或删除,多谢。

留言与评论(共有 条评论)
   
验证码: