SessionUtils
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的更多相关文章
- js base64加密,后台解密
这是为了解决页面发送post请求,传输密码,在页面的控制台可以看到密码的明文,所以先用base64把要传输的密码转换为非明文,然后在后台解密处理. base64encode.js // base64加 ...
- Hibernate5.2之HQL查询
Hibernate5.2之HQL查询 一. 介绍 Hibernate的 ...
- [Node.js] Node + Redis 实现分布式Session方案
原文地址: http://www.moye.me/?p=565 Session是什么? Session 是面向连接的状态信息,是对 Http 无状态协议的补充. Session 怎么工作? Sessi ...
- 序列化在Netty中的使用
Java序列化的缺点 1.无法跨语言 对于Java序列化后的字节数组,别的语言无法进行反序列化 2.序列化后的码流过大 3.序列化性能低 使用JDK自带的序列化进行对象的传输 被传输的,实现了序列化接 ...
- WebSocket 服务器4
Java Websocket实例 Websocket 2015-04-11 14:11:54 发布 您的评价: 4.4 收藏 6收藏 介绍 现很多网站为了实现即时通讯,所用 ...
- Java中Websocket使用实例解读
介绍 现在很多网站为了实现即时通讯,所用的技术都是轮询(polling).轮询是在特定的的时间间隔(如每1秒),由浏览器对服务器发出HTTP request,然后由服务器返回最新的数据给客服端的浏览器 ...
- mybatis学习笔记四(动态sql)
直接贴图,注解在代码上,其他的配置文件在学习一中就不贴了 1 数据库 2 实体类 package com.home.entity; /** * 此类是: 用户实体类 * @author hpc * @ ...
- mybatis学习笔记三(关联关系)
学习mybatis的关联关系,主要注解在代码上,这里不做解释.配置文件一样的就不贴了 1.关联关系表创建(学生对应老师 多对一) 学生老师表 2.表对应的实体类 package com.home.en ...
- mybatis学习笔记二(接口注解)
直接上代码,全部在代码里讲解. 1.实体类 package com.home.entity; /** * 此类是:user实体类 * @author hpc * @2017年1月10日下午9:36:5 ...
随机推荐
- HTTP缓存实现的原理
浏览器是如何知道使用缓存的,其实这都是通过http中,浏览器将最后修改时间发送请求给web服务器,web服务器收到请求后跟服务器上的文档最后修改的时间对比,如果web服务器上最新文档修改时间小于或者等 ...
- DOM 综合练习(二)
// 需求一: 二级联动菜单 <html> <head> <style type="text/css"> select{ width:100px ...
- scrapy 原理,结构,基本命令,item,spider,selector简述
原理,结构,基本命令,item,spider,selector简述 原理 (1)结构 (2)运行流程 实操 (1) scrapy命令: 注意先把python安装目录的scripts文件夹添加到环境变量 ...
- node.js---sails项目开发(6)--- 实现分页功能
只需要添加一个文件即可 api/blueprints/find.js 代码如下 /** * Module dependencies */ var util = require('util') ...
- tensorflow 的rnn的示例 ptb_word_lm.py 的完整代码
其训练数据源在我的空间里,名字为:tensorflow的ptb-word-lm示例的训练数据源.tgz 讲解参见另一篇文章: http://www.cnblogs.com/welhzh/p/6739 ...
- java反射基础知识(三)
原文地址:http://tutorials.jenkov.com/java-reflection/index.html http://www.cnblogs.com/penghongwei/p/329 ...
- Visual Studio 2012的Windows Service服务安装方式
windows服务应用程序是一种长期运行在操作系统后台的程序,它对于服务器环境特别适合,它没有用户界面,不会产生任何可视输出,任何用户输出都回被写进windows事件日志.计算机启动时,服务会自动开始 ...
- appcmd应用
appcmd资料: http://www.jb51.net/article/36024.htm 官方文档:https://docs.microsoft.com/zh-cn/iis/get-starte ...
- 查询前几条记录 top limit
SQL Server 数据库中的Top关键字可实现查询数据库表中的前几条数据,但是需要注意的是,Top关键字只能在SQL Server数据库中可以使用,而在MySQL数据库中就要使用具有同样功能的LI ...
- how can i get the source code path && file names from an ELF file(compired with -g)?
https://stackoverflow.com/questions/31333337/how-can-i-get-the-source-code-path-file-names-from-an-e ...