/**
* 使用JwtToken
* 从cookie中获取用户ID方法
* @param request
* @param tenantId
* @return
*/
private String getUserIdFromCookie(HttpServletRequest request, String tenantId) { String token = CookieUtils.getCookie(request, "v_authorization"); if (token == null) { return null; } JwtToken jwtToken = null; try { jwtToken = Utils.decodeSignatureToken(token, this.cookieEncryptKey); } catch (Exception e) { return null; } long expire = jwtToken.getExpire().getTime(); long now = DateUtils.getGMTTimeInMillis().longValue(); if (now > expire) { return null; } Map<String, String> payload = jwtToken.getPayload(); String uid = (String) payload.get("uid"); if (!tenantId.equals(payload.get("tenantId"))) { return null; } if (!Utils.isAnonymityUser(uid)) { return null; } return uid; }
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34
/**
* 获取用户真实IP方法
* @param request
* @return
*/
public String getIpAddress(HttpServletRequest request) { String ip = request.getHeader("x-forwarded-for"); if ((ip == null) || (ip.length() == 0) || ("unknown".equalsIgnoreCase(ip))) { ip = request.getHeader("Proxy-Client-IP"); } if ((ip == null) || (ip.length() == 0) || ("unknown".equalsIgnoreCase(ip))) { ip = request.getHeader("WL-Proxy-Client-IP"); } if ((ip == null) || (ip.length() == 0) || ("unknown".equalsIgnoreCase(ip))) { ip = request.getHeader("HTTP_CLIENT_IP"); } if ((ip == null) || (ip.length() == 0) || ("unknown".equalsIgnoreCase(ip))) { ip = request.getHeader("HTTP_X_FORWARDED_FOR"); } if ((ip == null) || (ip.length() == 0) || ("unknown".equalsIgnoreCase(ip))) { ip = request.getRemoteAddr(); } return ip; }