import com.diyfintech.constant.Constant.SuperAdmin;
import com.diyfintech.pojo.SysUser;
import org.apache.log4j.Logger; import javax.servlet.http.HttpServletRequest;
import java.util.List;
import java.util.Map; /**
*
* Session 工具类
*
*/
public final class SessionUtils { protected static final Logger logger = Logger.getLogger(SessionUtils.class); private static final String SESSION_USER = "session_user"; private static final String SESSION_VALIDATECODE = "session_validatecode";//验证码 private static final String SESSION_ACCESS_URLS = "session_access_urls"; //系统能够访问的URL private static final String SESSION_MENUBTN_MAP = "session_menubtn_map"; //系统菜单按钮 /**
* 设置session的值
* @param request
* @param key
* @param value
*/
public static void setAttr(HttpServletRequest request,String key,Object value){
request.getSession(true).setAttribute(key, value);
} /**
* 获取session的值
* @param request
* @param key
*/
public static Object getAttr(HttpServletRequest request,String key){
return request.getSession(true).getAttribute(key);
} /**
* 删除Session值
* @param request
* @param key
*/
public static void removeAttr(HttpServletRequest request,String key){
request.getSession(true).removeAttribute(key);
} /**
* 设置用户信息 到session
* @param request
* @param user
*/
public static void setUser(HttpServletRequest request,SysUser user){
request.getSession(true).setAttribute(SESSION_USER, user);
} /**
* 从session中获取用户信息
* @param request
* @return SysUser
*/
public static SysUser getUser(HttpServletRequest request){
return (SysUser)request.getSession(true).getAttribute(SESSION_USER);
} /**
* 从session中获取用户信息
* @param request
* @return SysUser
*/
public static void removeUser(HttpServletRequest request){
removeAttr(request, SESSION_USER);
} /**
* 设置验证码 到session
* @param request
* @param validateCode
*/
public static void setValidateCode(HttpServletRequest request,String validateCode){
request.getSession(true).setAttribute(SESSION_VALIDATECODE, validateCode);
} /**
* 从session中获取验证码
* @param request
* @return SysUser
*/
public static String getValidateCode(HttpServletRequest request){
return (String)request.getSession(true).getAttribute(SESSION_VALIDATECODE);
} /**
* 从session中获删除验证码
* @param request
* @return SysUser
*/
public static void removeValidateCode(HttpServletRequest request){
removeAttr(request, SESSION_VALIDATECODE);
} /**
* 判断当前登录用户是否超级管理员
* @param request
* @return
*/
public static boolean isAdmin(HttpServletRequest request){ //判断登录用户是否超级管理员
SysUser user = getUser(request);
if(user == null || !SuperAdmin.YES.key.endsWith(user.getIsSuperAdmin())){
return false;
}
return true;
} /**
*设置当前用户可以访问的urls
* @param request
* @param accessUrls
*/
public static void setAccessUrl(HttpServletRequest request,List<String> accessUrls){
setAttr(request, SESSION_ACCESS_URLS, accessUrls);
} /**
* 判断URL是否可访问
* @param request
* @return
*/
public static boolean isAccessUrl(HttpServletRequest request,String url){
List<String> accessUrls = (List)getAttr(request, SESSION_ACCESS_URLS);
if(accessUrls == null ||accessUrls.isEmpty() || !accessUrls.contains(url)){
return false;
}
return true;
} /**
* 设置菜单按钮
* @param request
* @param btnMap
*/
public static void setMemuBtnMap(HttpServletRequest request,Map<String,Object> btnMap){ //判断登录用户是否超级管理员
setAttr(request, SESSION_MENUBTN_MAP, btnMap);
} /**
* 获取菜单按钮
* @param request
* @param menuUri
*/
public static List<String> getMemuBtnListVal(HttpServletRequest request,String menuUri){
Map btnMap = (Map)getAttr(request, SESSION_MENUBTN_MAP);
if(btnMap == null || btnMap.isEmpty()){
return null;
}
return (List<String>)btnMap.get(menuUri);
} }

SessionUtils的更多相关文章

  1. js base64加密,后台解密

    这是为了解决页面发送post请求,传输密码,在页面的控制台可以看到密码的明文,所以先用base64把要传输的密码转换为非明文,然后在后台解密处理. base64encode.js // base64加 ...

  2. Hibernate5.2之HQL查询

    Hibernate5.2之HQL查询                                                                  一. 介绍 Hibernate的 ...

  3. [Node.js] Node + Redis 实现分布式Session方案

    原文地址: http://www.moye.me/?p=565 Session是什么? Session 是面向连接的状态信息,是对 Http 无状态协议的补充. Session 怎么工作? Sessi ...

  4. 序列化在Netty中的使用

    Java序列化的缺点 1.无法跨语言 对于Java序列化后的字节数组,别的语言无法进行反序列化 2.序列化后的码流过大 3.序列化性能低 使用JDK自带的序列化进行对象的传输 被传输的,实现了序列化接 ...

  5. WebSocket 服务器4

    Java Websocket实例 Websocket   2015-04-11 14:11:54 发布 您的评价:       4.4   收藏     6收藏 介绍 现很多网站为了实现即时通讯,所用 ...

  6. Java中Websocket使用实例解读

    介绍 现在很多网站为了实现即时通讯,所用的技术都是轮询(polling).轮询是在特定的的时间间隔(如每1秒),由浏览器对服务器发出HTTP request,然后由服务器返回最新的数据给客服端的浏览器 ...

  7. mybatis学习笔记四(动态sql)

    直接贴图,注解在代码上,其他的配置文件在学习一中就不贴了 1 数据库 2 实体类 package com.home.entity; /** * 此类是: 用户实体类 * @author hpc * @ ...

  8. mybatis学习笔记三(关联关系)

    学习mybatis的关联关系,主要注解在代码上,这里不做解释.配置文件一样的就不贴了 1.关联关系表创建(学生对应老师 多对一) 学生老师表 2.表对应的实体类 package com.home.en ...

  9. mybatis学习笔记二(接口注解)

    直接上代码,全部在代码里讲解. 1.实体类 package com.home.entity; /** * 此类是:user实体类 * @author hpc * @2017年1月10日下午9:36:5 ...

随机推荐

  1. 综合: Java 对象初始化过程

    class Fu { Fu() { show(); } void show() { System.out.println("xixi"); } } class Zi extends ...

  2. IDEA 录制宏+设置快捷键 实现写时编译

    参考: IDEA 录制宏+设置快捷键 实现写时编译:https://blog.csdn.net/wangjie919/article/details/79487981 IDEA 设置运行时不编译项目: ...

  3. 实现num1、num2交换,无中间变量

    num1=num1+num2; num2=num1-num2; num1=num1-num2;

  4. mysql完整备份与恢复

    1.备份单个数据库 mysql数据库自带了一个很好用的备份命令,就是mysqldump,他的基本使用如下: 语法:mysqldump -u 用户名 -p 数据库名 > 备份的文件名 备份一 1. ...

  5. Python基础、判断、循环、列表、字典,day1

    一.Python 简介 1.介绍 Python 是一个高层次的结合了解释性.编译性.互动性和面向对象的脚本语言. Python 的设计具有很强的可读性,相比其他语言经常使用英文关键字,其他语言的一些标 ...

  6. mongo常用查询

    复杂查询: and: or: lte,gte,=: and+lt:  , 逗号表示and, $lt小于写在值当中 查询实例: 找到含有指定数据文档 查找条件spcode有1个字符长度的文档 db.sp ...

  7. get app id

    Install Download the Web AppBuilder for ArcGIS (Developer Edition) ZIP file to your local drive and ...

  8. jQuery多级联动美化版Select下拉框

    在线演示 本地下载

  9. java没有指针

    先说结论:java没有指针,它使用对象引用来替代指针 备注:c/c++的引用和java的引用完全不是一个东西 c/c++的引用是同一块内存的不同名字 java的引用指向一个对象,引用本身也占用了内存 ...

  10. GitLab 安装与入门

    GitLab介绍: GitLab是一个利用 Ruby on Rails 开发的开源应用程序,实现一个自托管的Git项目仓库,可通过Web界面进行访问公开的或者私人项目. GitLab拥有与Github ...