LoginServiceImpl.java 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152
  1. package cn.com.usky.iot.controller.login;
  2. import cn.com.usky.iot.admin.dao.YtiotTAdminDao;
  3. import cn.com.usky.iot.auth.TokenAuthService;
  4. import cn.com.usky.utils.ListUtil;
  5. import cn.com.usky.utils.MD5Util;
  6. import com.alibaba.fastjson.JSONObject;
  7. import org.apache.log4j.Logger;
  8. import org.hibernate.HibernateException;
  9. import org.hibernate.Query;
  10. import org.hibernate.Session;
  11. import org.springframework.orm.hibernate3.HibernateCallback;
  12. import org.springframework.orm.hibernate3.HibernateTemplate;
  13. import javax.servlet.http.Cookie;
  14. import javax.servlet.http.HttpServletRequest;
  15. import javax.servlet.http.HttpServletResponse;
  16. import java.io.UnsupportedEncodingException;
  17. import java.security.NoSuchAlgorithmException;
  18. import java.sql.SQLException;
  19. import java.util.List;
  20. /**
  21. * @author laowo
  22. * @version v1.0
  23. * @date 2020/11/27 10:00
  24. * @description TODO
  25. **/
  26. public class LoginServiceImpl implements LoginService {
  27. private TokenAuthService tokenAuthService;
  28. public TokenAuthService getTokenAuthService() {
  29. return tokenAuthService;
  30. }
  31. public void setTokenAuthService(TokenAuthService tokenAuthService) {
  32. this.tokenAuthService = tokenAuthService;
  33. }
  34. private static final Logger LOGGER = Logger.getLogger(LoginServiceImpl.class);
  35. private HibernateTemplate hibernateTemplate;
  36. public HibernateTemplate getHibernateTemplate() {
  37. return hibernateTemplate;
  38. }
  39. public void setHibernateTemplate(HibernateTemplate hibernateTemplate) {
  40. this.hibernateTemplate = hibernateTemplate;
  41. }
  42. private YtiotTAdminDao ytiotTAdminDao;
  43. public YtiotTAdminDao getYtiotTAdminDao() {
  44. return ytiotTAdminDao;
  45. }
  46. public void setYtiotTAdminDao(YtiotTAdminDao ytiotTAdminDao) {
  47. this.ytiotTAdminDao = ytiotTAdminDao;
  48. }
  49. /**
  50. * 登录
  51. *
  52. * @param loginName
  53. * @param passWord
  54. * @param response
  55. * @param request
  56. * @return
  57. */
  58. @Override
  59. public String tologin(String loginName, String passWord, HttpServletResponse response, HttpServletRequest request) {
  60. String pwd = null;
  61. List userIdList = hibernateTemplate.executeFind(new HibernateCallback() {
  62. @Override
  63. public Object doInHibernate(Session session)
  64. throws HibernateException, SQLException {
  65. String sql = "select UQ_ADMIN_ID from ytiot_t_admin where V_LOGINNAME ='" + loginName + "'";
  66. Query query = session.createSQLQuery(sql);
  67. return query.list();
  68. }
  69. });
  70. if (ListUtil.isBlank(userIdList)) {
  71. JSONObject jsonObject = new JSONObject();
  72. jsonObject.put("Msg", "LOGIN NAME WRONG");
  73. jsonObject.put("ServerName", "www.jd-ioe.com/UskyIoT");
  74. jsonObject.put("check", "true");
  75. jsonObject.put("login", "false");
  76. return jsonObject.toString();
  77. }
  78. try {
  79. pwd = MD5Util.EncoderByMd5(passWord);
  80. } catch (NoSuchAlgorithmException e) {
  81. e.printStackTrace();
  82. } catch (UnsupportedEncodingException e) {
  83. e.printStackTrace();
  84. }
  85. String finalPwd = pwd;
  86. List password = hibernateTemplate.executeFind(new HibernateCallback() {
  87. @Override
  88. public Object doInHibernate(Session session)
  89. throws HibernateException, SQLException {
  90. String sql = "select V_ADMIN_NAME,V_PASSWORD from ytiot_t_admin where V_LOGINNAME ='" + loginName + "' and V_PASSWORD='" + finalPwd + "'";
  91. Query query = session.createSQLQuery(sql);
  92. return query.list();
  93. }
  94. });
  95. if (ListUtil.isBlank(password)) {
  96. JSONObject jsonObject = new JSONObject();
  97. jsonObject.put("Msg", "WRONG PASSWORD!!!");
  98. jsonObject.put("ServerName", "www.jd-ioe.com/UskyIoT");
  99. jsonObject.put("check", "true");
  100. jsonObject.put("login", "false");
  101. return jsonObject.toString();
  102. }
  103. JSONObject jsonObject = new JSONObject();
  104. jsonObject.put("chk", 1);
  105. jsonObject.put("href", "view/mainframe.jsp");
  106. jsonObject.put("login", "true");
  107. jsonObject.put("check", "true");
  108. jsonObject.put("ServerName", "www.jd-ioe.com/UskyIoT");
  109. //Token生成
  110. Long loginTime = System.currentTimeMillis() / 1000;
  111. String userId = (String) userIdList.get(0);
  112. String token = tokenAuthService.createToken(userId, loginTime);
  113. //设置响应token
  114. Cookie cookie = new Cookie(Constants.RESPONSE_TOKEN, token);
  115. //禁止JS读取cookie
  116. cookie.setHttpOnly(true);
  117. cookie.setPath(request.getContextPath());
  118. //有效期一个月
  119. cookie.setMaxAge(60 * 60 * 24 * 30);
  120. response.addCookie(cookie);
  121. return jsonObject.toString();
  122. }
  123. @Override
  124. public List getObjectByUserId(String userId) {
  125. return hibernateTemplate.executeFind(new HibernateCallback() {
  126. @Override
  127. public Object doInHibernate(Session session)
  128. throws HibernateException, SQLException {
  129. String sql = "select UQ_ADMIN_ID from ytiot_t_admin where UQ_ADMIN_ID ='" + userId + "'";
  130. Query query = session.createSQLQuery(sql);
  131. return query.list();
  132. }
  133. });
  134. }
  135. }