关于TokenProcessor令牌校验工具类废话不多说了,直接给大家贴代码了,一切内容就在下面一段代码中,具体代码详情如下所示:
代码如下 | 复制代码 |
publicclassTokenProcessor { privatelongprivious;// 上次生成表单标识号得时间值 privatestaticTokenProcessor instance =newTokenProcessor(); publicstaticString FORM_TOKEN_KEY ="FORM_TOKEN_KEY"; privateTokenProcessor() { } publicstaticTokenProcessor getInstance() { returninstance; } /** * 验证请求中得标识号是否有效,如果请求中的表单标识与当前用户session中的相同,返回结果true= */ publicsynchronizedbooleanisTokenValid(HttpServletRequest request) { // 为避免session对象不存在时候创建Session对象 HttpSession session = request.getSession(false); if(session ==null) { returnfalse; } String saved = (String) session.getAttribute(FORM_TOKEN_KEY); if(saved ==null) { returnfalse; } String token = (String) request.getParameter(FORM_TOKEN_KEY); if(token ==null) { returnfalse; } returnsaved.equals(token); } /** * 验证请求中得标识号是否有效,如果请求中的表单标识与当前用户session中的相同,返回结果true= */ publicsynchronizedbooleanisTokenValid(HttpServletRequest request,String token) { // 未避免session对象不存在时候创建Session对象 HttpSession session = request.getSession(false); if(session ==null) { returnfalse; } String saved = (String) session.getAttribute(FORM_TOKEN_KEY); if(saved ==null) { returnfalse; } if(token ==null) { returnfalse; } returnsaved.equals(token); } /** * 清除存储在当前用户session中的表单标识号 */ publicsynchronizedvoidreset(HttpServletRequest request) { HttpSession session = request.getSession(false); if(session ==null) { return; } session.removeAttribute(FORM_TOKEN_KEY); } /** * 产生表单标识号并将之保存在当前用户得session中 */ publicsynchronizedvoidsaveToken(HttpServletRequest request) { HttpSession session = request.getSession(); try{ byteid[] = session.getId().getBytes(); longcurrent = System.currentTimeMillis(); if(current == privious) { current++; } privious = current; bytenow[] = String.valueOf(current).getBytes(); MessageDigest md = MessageDigest.getInstance("MD5"); md.update(id); md.update(now); String token = toHex(md.digest()); session.setAttribute(FORM_TOKEN_KEY, token); }catch(NoSuchAlgorithmException e) { } } /** * 将一个字节数转换成十六进制得字符串 */ publicString toHex(bytebuffer[]) { StringBuffer sb =newStringBuffer(buffer.length *2); for(inti =0; i < buffer.length; i++) { sb.append(Character.forDigit((buffer[i] &0x60) >>4,16)); sb.append(Character.forDigit(buffer[i] &0x0f,16)); } returnsb.toString(); } } |
茶杯头甜蜜终章dlc 官方手机版v1.0.0.3
下载火柴人传说暗影格斗内置菜单 最新版v3.0.1
下载荒野乱斗测试服 安卓版v61.10.3
下载荒野乱斗彩虹服 安卓版v61.10.3
下载寒霜启示录 安卓版v1.25.10
寒霜启示录是一款生存模拟游戏,不少玩家可能对于末日都有着自己
末日城堡免广告版 安卓最新版v0.7.1
末日城堡免广告版是一款非常好玩的模拟经营类游戏,内部可以不看
甜蜜人生模拟器 最新版v1.4.5
甜蜜人生模拟器是一款非常好玩的模拟恋爱手游,玩家在这里能够对
武器锻造师内置功能菜单 v10.4
武器锻造师内置菜单版是游戏的破解版本,在该版本中为玩家提供了
开放空间overfield 安卓版v1.0.5
开放空间Overfield是一款箱庭养成经营手游,让你在广阔