UserInterceptor.java 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  1. package com.yihu.wlyy.interceptors;
  2. import java.util.Date;
  3. import javax.servlet.http.HttpServletRequest;
  4. import javax.servlet.http.HttpServletResponse;
  5. import org.apache.commons.lang3.StringUtils;
  6. import org.json.JSONObject;
  7. import org.springframework.web.servlet.ModelAndView;
  8. import com.yihu.wlyy.entity.security.Token;
  9. import com.yihu.wlyy.util.DateUtil;
  10. import com.yihu.wlyy.util.SystemConf;
  11. import com.yihu.wlyy.util.SystemData;
  12. /**
  13. * 公共方法,权限简单校验
  14. * @author George
  15. *
  16. */
  17. public class UserInterceptor extends BaseInterceptor {
  18. @Override
  19. public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
  20. try {
  21. response.setCharacterEncoding("UTF-8");
  22. JSONObject json = getAgent(request);
  23. if (json == null) {
  24. // 未登录
  25. response.getOutputStream().write(error(SystemConf.NOT_LOGIN, "请登录后再操作!").getBytes());
  26. return false;
  27. }
  28. // 获取用户token
  29. String tokenStr = json.has("token") ? json.getString("token") : "";
  30. String uid = json.has("uid") ? json.getString("uid") : "";
  31. String imei = json.has("imei") ? json.getString("imei") : "";
  32. String openid = json.has("openid") ? json.getString("openid") : "";
  33. if (StringUtils.isEmpty(imei)) {
  34. imei = openid;
  35. }
  36. Token token = null;
  37. if (SystemData.doctorTokens.containsKey(uid)) {
  38. token = SystemData.doctorTokens.get(uid);
  39. } else if (SystemData.patientTokens.containsKey(uid)) {
  40. token = SystemData.patientTokens.get(uid);
  41. } else if (SystemData.wxPatientTokens.containsKey(uid)) {
  42. token = SystemData.wxPatientTokens.get(uid);
  43. }
  44. if (token == null) {
  45. token = tokenDao.findByToken(tokenStr);
  46. if (token != null) {
  47. switch (token.getPlatform()) {
  48. case 1:
  49. SystemData.patientTokens.put(uid, token);
  50. break;
  51. case 2:
  52. SystemData.doctorTokens.put(uid, token);
  53. break;
  54. case 3:
  55. SystemData.wxPatientTokens.put(uid, token);
  56. break;
  57. }
  58. }
  59. }
  60. if (token == null) {
  61. // 未登录
  62. response.getOutputStream().write(error(SystemConf.NOT_LOGIN, "请登录后再操作!").getBytes());
  63. return false;
  64. } else {
  65. if (token.getTimeout().getTime() < new Date().getTime()) {
  66. // 登录超时
  67. response.getOutputStream().write(error(SystemConf.LOGIN_TIMEOUT, "登录超时,请重新登录").getBytes());
  68. return false;
  69. } else if (!StringUtils.equals(tokenStr, token.getToken()) || !StringUtils.equals(uid, token.getUser()) || !StringUtils.equals(imei, token.getImei())) {
  70. // 别处登录
  71. response.getOutputStream().write(error(SystemConf.LOGIN_OTHER, "帐号在别处登录,请重新登录").getBytes());
  72. return false;
  73. } else {
  74. // 一天只更新一次
  75. if (DateUtil.getDays(token.getCzrq(), DateUtil.getNowDateShort()) != 0) {
  76. // 今天未更新,则更新缓存
  77. token.setCzrq(new Date());
  78. // 更新内存
  79. SystemData.doctorTokens.put(uid, token);
  80. // 更新数据库
  81. tokenDao.save(token);
  82. }
  83. }
  84. }
  85. } catch (Exception e) {
  86. e.printStackTrace();
  87. }
  88. return true;
  89. }
  90. @Override
  91. public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
  92. }
  93. @Override
  94. public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
  95. }
  96. }