SubscribeSample.java 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268
  1. package com.template.common.utils;
  2. import com.alibaba.fastjson.JSONObject;
  3. import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
  4. import com.baomidou.mybatisplus.core.toolkit.ObjectUtils;
  5. import com.template.model.mqtt.MqttConfiguration;
  6. import com.template.model.mqtt.MqttPushClient;
  7. import com.template.model.mqtt.SpringUtil;
  8. import com.template.model.pojo.HouseLock;
  9. import com.template.model.pojo.HouseNumber;
  10. import com.template.model.pojo.UnlockingRecord;
  11. import com.template.services.impl.AlarmMessageServiceImpl;
  12. import com.template.services.impl.HouseLockServiceImpl;
  13. import com.template.services.impl.HouseNumberServiceImpl;
  14. import com.template.services.impl.UnlockingRecordServiceImpl;
  15. import lombok.extern.slf4j.Slf4j;
  16. import org.eclipse.paho.client.mqttv3.*;
  17. import org.eclipse.paho.client.mqttv3.persist.MemoryPersistence;
  18. import org.springframework.stereotype.Component;
  19. import java.text.SimpleDateFormat;
  20. import java.time.LocalDateTime;
  21. import java.time.format.DateTimeFormatter;
  22. import java.util.List;
  23. /**
  24. * 订阅
  25. *
  26. * @author issuser
  27. */
  28. @Component
  29. @Slf4j
  30. public class SubscribeSample{
  31. private MqttPushClient client;
  32. private MqttConfiguration mqttConfiguration;
  33. public SubscribeSample(MqttPushClient client ,MqttConfiguration mqttConfiguration) {
  34. this.client = client;
  35. this.mqttConfiguration = mqttConfiguration;
  36. }
  37. // @Scheduled(cron = "0 10 * * * ? ")
  38. public void mqtt() {
  39. String HOST = "tcp://www.qspms.cn:1883";
  40. String TOPIC = "smartLock/open/device/2d00b258183146c0a2b19f55250c4596";
  41. int qos = 1;
  42. String clientid = "open_cloud_smartLock_2d00b258183146c0a2b19f55250c4596";
  43. String userName = "2d00b258183146c0a2b19f55250c4596";
  44. String passWord = "9ac03de350720057";
  45. try {
  46. // host为主机名,test为clientid即连接MQTT的客户端ID,一般以客户端唯一标识符表示,MemoryPersistence设置clientid的保存形式,默认为以内存保存
  47. MqttClient client = new MqttClient(HOST, clientid, new MemoryPersistence());
  48. // MQTT的连接设置
  49. MqttConnectOptions options = new MqttConnectOptions();
  50. // 设置是否清空session,这里如果设置为false表示服务器会保留客户端的连接记录,这里设置为true表示每次连接到服务器都以新的身份连接
  51. options.setCleanSession(true);
  52. // 设置连接的用户名
  53. options.setUserName(userName);
  54. // 设置连接的密码
  55. options.setPassword(passWord.toCharArray());
  56. // 设置超时时间 单位为秒
  57. options.setConnectionTimeout(10);
  58. // 设置会话心跳时间 单位为秒 服务器会每隔1.5*20秒的时间向客户端发送个消息判断客户端是否在线,但这个方法并没有重连的机制
  59. options.setKeepAliveInterval(20);
  60. // 设置回调函数
  61. client.setCallback(new MqttCallback() {
  62. @Override
  63. public void connectionLost(Throwable cause) {
  64. log.info(cause.getMessage());
  65. try {
  66. log.info("==============》》》[MQTT] 连接断开,5S之后尝试重连...");
  67. Thread.sleep(5000);
  68. MqttPushClient mqttPushClient = new MqttPushClient();
  69. mqttPushClient.connect(mqttConfiguration);
  70. if(MqttPushClient.getClient().isConnected()){
  71. log.info("=============>>重连成功");
  72. }
  73. } catch (Exception e) {
  74. log.error("=============>>>[MQTT] 连接断开,重连失败!<<=============");
  75. }
  76. }
  77. @Override
  78. public void messageArrived(String topic, MqttMessage message) {
  79. //实例化入库方法 这里就用到SpringUtil类 来手动的注入
  80. HouseLockServiceImpl houseLockService = SpringUtil.getBean(HouseLockServiceImpl.class);
  81. HouseNumberServiceImpl houseNumberService = SpringUtil.getBean(HouseNumberServiceImpl.class);
  82. UnlockingRecordServiceImpl unlockingRecordService = SpringUtil.getBean(UnlockingRecordServiceImpl.class);
  83. AlarmMessageServiceImpl alarmMessageService = SpringUtil.getBean(AlarmMessageServiceImpl.class);
  84. System.out.println("topic:" + topic);
  85. System.out.println("Qos:" + message.getQos());
  86. System.out.println("message content:" + new String(message.getPayload()));
  87. JSONObject s = MessageDecryptUtil.decryptMessage(message.toString(), "6edfcc178c0f415d8e6628238761976f", "2d00b258183146c0a2b19f55250c4596");
  88. String protocol = s.getString("protocol");
  89. // 设备消息上报
  90. if ("2".equals(protocol)) {
  91. UnlockingRecord unlockingRecord = new UnlockingRecord();
  92. unlockingRecord.setType("消息类型");
  93. String data = s.getString("data");
  94. System.out.println("data = " + data);
  95. JSONObject jsonObject = JSONObject.parseObject(data);
  96. System.out.println("jsonObject = " + jsonObject);
  97. // 结果
  98. String result = jsonObject.getString("result");
  99. // 时间
  100. String messageTime = jsonObject.getString("messageTime");
  101. // 房间luid
  102. String luid = jsonObject.getString("luid");
  103. // 找到房间号
  104. LambdaQueryWrapper<HouseLock> WrapperHL = new LambdaQueryWrapper<>();
  105. WrapperHL.eq(HouseLock::getEquipmentType, luid);
  106. List<HouseLock> list = houseLockService.list(WrapperHL);
  107. if (ObjectUtils.isNotEmpty(list) && list.size() > 0) {
  108. HouseLock houseLock = list.get(0);
  109. Integer houseNumberId = houseLock.getHouseNumberId();
  110. HouseNumber byId = houseNumberService.getById(houseNumberId);
  111. unlockingRecord.setHouseNumberId(houseNumberId);
  112. if (ObjectUtils.isNotEmpty(byId)) {
  113. String roomNumber = byId.getRoomNumber();
  114. unlockingRecord.setRoomNumber(roomNumber);
  115. unlockingRecord.setHouseNumberId(houseNumberId);
  116. }
  117. }
  118. // 消息类型
  119. String messageType = jsonObject.getString("messageType");
  120. SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
  121. String format = sdf.format(Long.valueOf(messageTime));
  122. unlockingRecord.setDateTime(format);
  123. if ("1".equals(messageType)) {
  124. //密码开锁
  125. unlockingRecord.setUnlockType("密码开锁");
  126. } else if ("2".equals(messageType)) {
  127. // 远程开锁
  128. unlockingRecord.setUnlockType("远程开锁");
  129. } else if ("3".equals(messageType)) {
  130. //无网络密码开锁
  131. unlockingRecord.setUnlockType("无网络密码开锁");
  132. } else if ("5".equals(messageType)) {
  133. //人脸开锁
  134. unlockingRecord.setUnlockType("人脸开锁");
  135. } else if ("10".equals(messageType)) {
  136. // 电池电量更新
  137. unlockingRecord.setUnlockType("电池电量更新");
  138. }
  139. DateTimeFormatter dateTimeFormatter1 = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss");
  140. unlockingRecord.setCreateTime(LocalDateTime.now().format(dateTimeFormatter1));
  141. unlockingRecord.setUpdateTime(LocalDateTime.now().format(dateTimeFormatter1));
  142. unlockingRecord.setCreateUser("1");
  143. unlockingRecord.setUpdateUser("1");
  144. unlockingRecordService.getSave(unlockingRecord);
  145. } else if ("3".equals(protocol)) {
  146. // AlarmMessage alarmMessage = new AlarmMessage();
  147. UnlockingRecord alarmMessage = new UnlockingRecord();
  148. alarmMessage.setType("预警类型");
  149. String data = s.getString("data");
  150. JSONObject jsonObject = JSONObject.parseObject(data);
  151. // 消息类型
  152. String messageType = jsonObject.getString("messageType");
  153. // 时间
  154. String messageTime = jsonObject.getString("messageTime");
  155. SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
  156. String format = sdf.format(Long.valueOf(messageTime));
  157. alarmMessage.setDateTime(format);
  158. // 房间luid
  159. String luid = jsonObject.getString("luid");
  160. // 找到房间号
  161. LambdaQueryWrapper<HouseLock> WrapperHL = new LambdaQueryWrapper<>();
  162. WrapperHL.eq(HouseLock::getEquipmentType, luid);
  163. List<HouseLock> list = houseLockService.list(WrapperHL);
  164. if (ObjectUtils.isNotEmpty(list) && list.size() > 0) {
  165. HouseLock houseLock = list.get(0);
  166. Integer houseNumberId = houseLock.getHouseNumberId();
  167. HouseNumber byId = houseNumberService.getById(houseNumberId);
  168. if (ObjectUtils.isNotEmpty(byId)) {
  169. String roomNumber = byId.getRoomNumber();
  170. alarmMessage.setRoomNumber(roomNumber);
  171. alarmMessage.setHouseNumberId(houseNumberId);
  172. }
  173. }
  174. if ("5".equals(messageType)) {
  175. // 低电量
  176. alarmMessage.setUnlockType("低电量");
  177. } else if ("1".equals(messageType)) {
  178. alarmMessage.setUnlockType("密码错误(连续失败五次)");
  179. } else if ("4".equals(messageType)) {
  180. alarmMessage.setUnlockType("防拆告警");
  181. }
  182. DateTimeFormatter dateTimeFormatter1 = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss");
  183. alarmMessage.setCreateTime(LocalDateTime.now().format(dateTimeFormatter1));
  184. alarmMessage.setUpdateTime(LocalDateTime.now().format(dateTimeFormatter1));
  185. alarmMessage.setCreateUser("1");
  186. alarmMessage.setUpdateUser("1");
  187. unlockingRecordService.getSave(alarmMessage);
  188. }
  189. }
  190. @Override
  191. public void deliveryComplete(IMqttDeliveryToken token) {
  192. System.out.println("deliveryComplete---------" + token.isComplete());
  193. }
  194. });
  195. client.connect(options);
  196. // 订阅消息
  197. client.subscribe(TOPIC, qos);
  198. System.out.println("订阅完成");
  199. } catch (Exception e) {
  200. e.printStackTrace();
  201. }
  202. }
  203. /**
  204. * 编辑连接信息
  205. *
  206. * @param userName
  207. * @param password
  208. * @param outTime
  209. * @param KeepAlive
  210. * @return
  211. */
  212. private MqttConnectOptions getOption(String userName, String password, int outTime, int KeepAlive) {
  213. //MQTT连接设置
  214. MqttConnectOptions option = new MqttConnectOptions();
  215. //设置是否清空session,false表示服务器会保留客户端的连接记录,true表示每次连接到服务器都以新的身份连接
  216. option.setCleanSession(false);
  217. //设置连接的用户名
  218. option.setUserName(userName);
  219. //设置连接的密码
  220. option.setPassword(password.toCharArray());
  221. //设置超时时间 单位为秒
  222. option.setConnectionTimeout(outTime);
  223. //设置会话心跳时间 单位为秒 服务器会每隔(1.5*keepTime)秒的时间向客户端发送个消息判断客户端是否在线,但这个方法并没有重连的机制
  224. option.setKeepAliveInterval(KeepAlive);
  225. //setWill方法,如果项目中需要知道客户端是否掉线可以调用该方法。设置最终端口的通知消息
  226. //option.setWill(topic, "close".getBytes(StandardCharsets.UTF_8), 2, true);
  227. option.setMaxInflight(1000);
  228. return option;
  229. }
  230. }