WeChatPushMessageTemplate.java 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285
  1. package com.java110.job.task.wechat;
  2. import com.alibaba.fastjson.JSON;
  3. import com.java110.core.factory.WechatFactory;
  4. import com.java110.dto.RoomDto;
  5. import com.java110.dto.community.CommunityDto;
  6. import com.java110.dto.notice.NoticeDto;
  7. import com.java110.dto.owner.OwnerAppUserDto;
  8. import com.java110.dto.owner.OwnerRoomRelDto;
  9. import com.java110.dto.smallWeChat.SmallWeChatDto;
  10. import com.java110.dto.smallWechatAttr.SmallWechatAttrDto;
  11. import com.java110.dto.task.TaskDto;
  12. import com.java110.entity.wechat.Content;
  13. import com.java110.entity.wechat.Data;
  14. import com.java110.entity.wechat.PropertyFeeTemplateMessage;
  15. import com.java110.intf.community.INoticeInnerServiceSMO;
  16. import com.java110.intf.community.IRoomInnerServiceSMO;
  17. import com.java110.intf.store.ISmallWeChatInnerServiceSMO;
  18. import com.java110.intf.store.ISmallWechatAttrInnerServiceSMO;
  19. import com.java110.intf.user.IOwnerAppUserInnerServiceSMO;
  20. import com.java110.intf.user.IOwnerRoomRelInnerServiceSMO;
  21. import com.java110.job.quartz.TaskSystemQuartz;
  22. import com.java110.utils.cache.MappingCache;
  23. import com.java110.utils.util.DateUtil;
  24. import org.slf4j.Logger;
  25. import org.slf4j.LoggerFactory;
  26. import org.springframework.beans.factory.annotation.Autowired;
  27. import org.springframework.http.ResponseEntity;
  28. import org.springframework.stereotype.Component;
  29. import org.springframework.web.client.RestTemplate;
  30. import java.util.Date;
  31. import java.util.List;
  32. /**
  33. * @program: MicroCommunity
  34. * @description: 微信公众号主动推送信息
  35. * @author: wuxw
  36. * @create: 2020-06-15 13:35
  37. **/
  38. @Component
  39. public class WeChatPushMessageTemplate extends TaskSystemQuartz {
  40. private static Logger logger = LoggerFactory.getLogger(WeChatPushMessageTemplate.class);
  41. @Autowired
  42. private INoticeInnerServiceSMO noticeInnerServiceSMOImpl;
  43. @Autowired
  44. private ISmallWeChatInnerServiceSMO smallWeChatInnerServiceSMOImpl;
  45. @Autowired
  46. private ISmallWechatAttrInnerServiceSMO smallWechatAttrInnerServiceSMOImpl;
  47. @Autowired
  48. private IOwnerAppUserInnerServiceSMO ownerAppUserInnerServiceSMOImpl;
  49. @Autowired
  50. private IRoomInnerServiceSMO roomInnerServiceSMOImpl;
  51. @Autowired
  52. private IOwnerRoomRelInnerServiceSMO ownerRoomRelInnerServiceSMOImpl;
  53. @Autowired
  54. private RestTemplate outRestTemplate;
  55. //模板信息推送地址
  56. private static String sendMsgUrl = "https://api.weixin.qq.com/cgi-bin/message/template/send?access_token=";
  57. @Override
  58. protected void process(TaskDto taskDto) {
  59. logger.debug("开始执行微信模板信息推送" + taskDto.toString());
  60. // 获取小区
  61. List<CommunityDto> communityDtos = getAllCommunity();
  62. for (CommunityDto communityDto : communityDtos) {
  63. try {
  64. publishMsg(taskDto, communityDto);
  65. } catch (Exception e) {
  66. logger.error("推送消息失败", e);
  67. }
  68. }
  69. }
  70. private void publishMsg(TaskDto taskDto, CommunityDto communityDto) throws Exception {
  71. //查询公众号配置
  72. SmallWeChatDto smallWeChatDto = new SmallWeChatDto();
  73. smallWeChatDto.setWeChatType("1100");
  74. smallWeChatDto.setObjType(SmallWeChatDto.OBJ_TYPE_COMMUNITY);
  75. smallWeChatDto.setObjId(communityDto.getCommunityId());
  76. List<SmallWeChatDto> smallWeChatDtos = smallWeChatInnerServiceSMOImpl.querySmallWeChats(smallWeChatDto);
  77. if (smallWeChatDto == null || smallWeChatDtos.size() <= 0) {
  78. logger.info("未配置微信公众号信息,定时任务执行结束");
  79. return;
  80. }
  81. SmallWeChatDto weChatDto = smallWeChatDtos.get(0);
  82. SmallWechatAttrDto smallWechatAttrDto = new SmallWechatAttrDto();
  83. smallWechatAttrDto.setCommunityId(communityDto.getCommunityId());
  84. smallWechatAttrDto.setWechatId(weChatDto.getWeChatId());
  85. smallWechatAttrDto.setSpecCd(SmallWechatAttrDto.SPEC_CD_WECHAT_TEMPLATE);
  86. List<SmallWechatAttrDto> smallWechatAttrDtos = smallWechatAttrInnerServiceSMOImpl.querySmallWechatAttrs(smallWechatAttrDto);
  87. if (smallWechatAttrDtos == null || smallWechatAttrDtos.size() <= 0) {
  88. logger.info("未配置微信公众号消息模板");
  89. return;
  90. }
  91. String templateId = smallWechatAttrDtos.get(0).getValue();
  92. String accessToken = WechatFactory.getAccessToken(weChatDto.getAppId(), weChatDto.getAppSecret());
  93. if (accessToken == null || accessToken == "") {
  94. logger.info("推送微信模板,获取accessToken失败:{}", accessToken);
  95. return;
  96. }
  97. //
  98. NoticeDto noticeDto = new NoticeDto();
  99. noticeDto.setCommunityId(communityDto.getCommunityId());
  100. noticeDto.setPage(1);
  101. noticeDto.setRow(50);
  102. noticeDto.setState(NoticeDto.STATE_WAIT);
  103. noticeDto.setNoticeTypeCd(NoticeDto.NOTICE_TYPE_OWNER_WECHAT);
  104. List<NoticeDto> noticeDtos = noticeInnerServiceSMOImpl.queryNotices(noticeDto);
  105. if (noticeDtos == null || noticeDtos.size() < 1) {
  106. return;
  107. }
  108. for (NoticeDto tmpNotice : noticeDtos) {
  109. try {
  110. doSentWechat(tmpNotice, templateId, accessToken);
  111. } catch (Exception e) {
  112. logger.error("通知异常", e);
  113. }
  114. }
  115. }
  116. private void doSentWechat(NoticeDto noticeDto, String templateId, String accessToken) throws Exception {
  117. Date startTime = DateUtil.getDateFromString(noticeDto.getStartTime(), DateUtil.DATE_FORMATE_STRING_A);
  118. Date nowTime = DateUtil.getCurrentDate();
  119. if (startTime.getTime() > nowTime.getTime()) { //还没有到时间
  120. return;
  121. }
  122. String objType = noticeDto.getObjType();
  123. switch (objType) {
  124. case NoticeDto.OBJ_TYPE_COMMUNITY:
  125. sendAllOwner(noticeDto, templateId, accessToken);
  126. break;
  127. case NoticeDto.OBJ_TYPE_FLOOR:
  128. sendFloorOwner(noticeDto, templateId, accessToken);
  129. break;
  130. case NoticeDto.OBJ_TYPE_UNIT:
  131. sendUnitOwner(noticeDto, templateId, accessToken);
  132. break;
  133. case NoticeDto.OBJ_TYPE_ROOM:
  134. sendRoomOwner(noticeDto, templateId, accessToken);
  135. break;
  136. }
  137. NoticeDto tmpNoticeDto = new NoticeDto();
  138. tmpNoticeDto.setNoticeId(noticeDto.getNoticeId());
  139. tmpNoticeDto.setState(NoticeDto.STATE_FINISH);
  140. noticeInnerServiceSMOImpl.updateNotice(tmpNoticeDto);
  141. }
  142. private void sendFloorOwner(NoticeDto noticeDto, String templateId, String accessToken) {
  143. RoomDto roomDto = new RoomDto();
  144. roomDto.setCommunityId(noticeDto.getCommunityId());
  145. roomDto.setFloorId(noticeDto.getObjId());
  146. List<RoomDto> roomDtos = roomInnerServiceSMOImpl.queryRooms(roomDto);
  147. for (RoomDto tmpRoomDto : roomDtos) {
  148. if (!RoomDto.STATE_SELL.equals(tmpRoomDto.getState())) {
  149. continue;
  150. }
  151. OwnerRoomRelDto ownerRoomRelDto = new OwnerRoomRelDto();
  152. ownerRoomRelDto.setRoomId(tmpRoomDto.getRoomId());
  153. List<OwnerRoomRelDto> ownerRoomRelDtos = ownerRoomRelInnerServiceSMOImpl.queryOwnerRoomRels(ownerRoomRelDto);
  154. if (ownerRoomRelDtos == null || ownerRoomRelDtos.size() < 1) {
  155. continue;
  156. }
  157. OwnerAppUserDto ownerAppUserDto = new OwnerAppUserDto();
  158. ownerAppUserDto.setAppType(OwnerAppUserDto.APP_TYPE_WECHAT);
  159. ownerAppUserDto.setMemberId(ownerRoomRelDtos.get(0).getOwnerId());
  160. List<OwnerAppUserDto> ownerAppUserDtos = ownerAppUserInnerServiceSMOImpl.queryOwnerAppUsers(ownerAppUserDto);
  161. doSend(ownerAppUserDtos, noticeDto, templateId, accessToken);
  162. }
  163. }
  164. private void sendUnitOwner(NoticeDto noticeDto, String templateId, String accessToken) {
  165. RoomDto roomDto = new RoomDto();
  166. roomDto.setCommunityId(noticeDto.getCommunityId());
  167. roomDto.setUnitId(noticeDto.getObjId());
  168. List<RoomDto> roomDtos = roomInnerServiceSMOImpl.queryRooms(roomDto);
  169. for (RoomDto tmpRoomDto : roomDtos) {
  170. if (!RoomDto.STATE_SELL.equals(tmpRoomDto.getState())) {
  171. continue;
  172. }
  173. OwnerRoomRelDto ownerRoomRelDto = new OwnerRoomRelDto();
  174. ownerRoomRelDto.setRoomId(tmpRoomDto.getRoomId());
  175. List<OwnerRoomRelDto> ownerRoomRelDtos = ownerRoomRelInnerServiceSMOImpl.queryOwnerRoomRels(ownerRoomRelDto);
  176. if (ownerRoomRelDtos == null || ownerRoomRelDtos.size() < 1) {
  177. continue;
  178. }
  179. OwnerAppUserDto ownerAppUserDto = new OwnerAppUserDto();
  180. ownerAppUserDto.setAppType(OwnerAppUserDto.APP_TYPE_WECHAT);
  181. ownerAppUserDto.setMemberId(ownerRoomRelDtos.get(0).getOwnerId());
  182. List<OwnerAppUserDto> ownerAppUserDtos = ownerAppUserInnerServiceSMOImpl.queryOwnerAppUsers(ownerAppUserDto);
  183. doSend(ownerAppUserDtos, noticeDto, templateId, accessToken);
  184. }
  185. }
  186. private void sendRoomOwner(NoticeDto noticeDto, String templateId, String accessToken) {
  187. RoomDto roomDto = new RoomDto();
  188. roomDto.setCommunityId(noticeDto.getCommunityId());
  189. roomDto.setRoomId(noticeDto.getObjId());
  190. List<RoomDto> roomDtos = roomInnerServiceSMOImpl.queryRooms(roomDto);
  191. for (RoomDto tmpRoomDto : roomDtos) {
  192. if (!RoomDto.STATE_SELL.equals(tmpRoomDto.getState())) {
  193. continue;
  194. }
  195. OwnerRoomRelDto ownerRoomRelDto = new OwnerRoomRelDto();
  196. ownerRoomRelDto.setRoomId(tmpRoomDto.getRoomId());
  197. List<OwnerRoomRelDto> ownerRoomRelDtos = ownerRoomRelInnerServiceSMOImpl.queryOwnerRoomRels(ownerRoomRelDto);
  198. if (ownerRoomRelDtos == null || ownerRoomRelDtos.size() < 1) {
  199. continue;
  200. }
  201. OwnerAppUserDto ownerAppUserDto = new OwnerAppUserDto();
  202. ownerAppUserDto.setAppType(OwnerAppUserDto.APP_TYPE_WECHAT);
  203. ownerAppUserDto.setMemberId(ownerRoomRelDtos.get(0).getOwnerId());
  204. List<OwnerAppUserDto> ownerAppUserDtos = ownerAppUserInnerServiceSMOImpl.queryOwnerAppUsers(ownerAppUserDto);
  205. doSend(ownerAppUserDtos, noticeDto, templateId, accessToken);
  206. }
  207. }
  208. private void sendAllOwner(NoticeDto noticeDto, String templateId, String accessToken) {
  209. OwnerAppUserDto ownerAppUserDto = new OwnerAppUserDto();
  210. ownerAppUserDto.setAppType(OwnerAppUserDto.APP_TYPE_WECHAT);
  211. List<OwnerAppUserDto> ownerAppUserDtos = ownerAppUserInnerServiceSMOImpl.queryOwnerAppUsers(ownerAppUserDto);
  212. doSend(ownerAppUserDtos, noticeDto, templateId, accessToken);
  213. }
  214. private void doSend(List<OwnerAppUserDto> ownerAppUserDtos, NoticeDto noticeDto, String templateId, String accessToken) {
  215. String wechatUrl = MappingCache.getValue("OWNER_WECHAT_URL") + "/#/pages/notice/detail/detail?noticeId=";
  216. for (OwnerAppUserDto appUserDto : ownerAppUserDtos) {
  217. Data data = new Data();
  218. PropertyFeeTemplateMessage templateMessage = new PropertyFeeTemplateMessage();
  219. templateMessage.setTemplate_id(templateId);
  220. templateMessage.setTouser(appUserDto.getOpenId());
  221. data.setFirst(new Content(noticeDto.getTitle()));
  222. data.setKeyword1(new Content(noticeDto.getTitle()));
  223. data.setKeyword2(new Content(noticeDto.getStartTime()));
  224. data.setKeyword3(new Content(noticeDto.getContext()));
  225. data.setRemark(new Content("如有疑问请联系相关物业人员"));
  226. templateMessage.setData(data);
  227. templateMessage.setUrl(wechatUrl + noticeDto.getNoticeId());
  228. logger.info("发送模板消息内容:{}", JSON.toJSONString(templateMessage));
  229. ResponseEntity<String> responseEntity = outRestTemplate.postForEntity(sendMsgUrl + accessToken, JSON.toJSONString(templateMessage), String.class);
  230. logger.info("微信模板返回内容:{}", responseEntity);
  231. }
  232. }
  233. }