1:业务背景
模板消息仅用于公众号向用户发送重要的服务通知,只能用于符合其要求的服务场景中,如信用卡刷卡通知,商品购买成功通知等。不支持广告等营销类消息以及其它所有可能对用户造成骚扰的消息。
2:公众号设置
2.1 申请模板消息功能
接口权限
2.2 设置所属行业
2.3 选取模板
3:代码实践
根据模板参数设置模板数据
TreeMap<String, String> params = new TreeMap<String, String>();
params.put("first", "您收到新的任务消息:" + task.getTasktitle());
params.put("keyword1", task.getTaskid());
params.put("keyword2", createUser.getUserfull());
DateTimeFormatter dateTimeFormatter = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss");
LocalDateTime localDateTime = LocalDateTime.now();
params.put("keyword3", localDateTime.format(dateTimeFormatter));
params.put("remark", "请您及时处理!");
获取accessToken&openid ,请查看:
https://blog.csdn.net/weixin_42338555/article/details/85627272
注意:access token 有次数限制,腾讯默认2小时有效。
List<TemplateMsgResult> results = new ArrayList<TemplateMsgResult>();
WeixinTokenBase accessToken = wechatAuthService.getAccessToken();
logger.debug("start to send message,userid["+userid+"],accessToken:"+accessToken);
TreeMap<String,TreeMap<String,String>> params = new TreeMap<String,TreeMap<String,String>>();
dataParams.forEach((key,value)->{
params.put(key, WechatTemplateMsg.item(value, "#173177"));//消息显示颜色
});
WechatTemplateMsg wechatTemplateMsg = new WechatTemplateMsg();
wechatTemplateMsg.setTemplate_id("*******");//模板id 每个公众号id都不相同
wechatTemplateMsg.setTouser("openid");//用户openid
wechatTemplateMsg.setUrl(url); //消息url,若url不为空,则消息接收者直接点击查看将跳转至该链接
wechatTemplateMsg.setData(params);
String data = JsonHelper.toJson(wechatTemplateMsg);;
TemplateMsgResult result = sendTemplateMsg(accessToken.getAccess_token(), data);
results.add(result);
模板消息实体:
public class WechatTemplateMsg {
private String touser; // 接收者openid
private String template_id; // 模板ID
private String url; // 模板跳转链接
private TreeMap<String, TreeMap<String, String>> data; // data数据
/**
* 参数
* @param value
* @param color 可不填
* @return
*/
public static TreeMap<String, String> item(String value, String color) {
TreeMap<String, String> params = new TreeMap<String, String>();
params.put("value", value);
params.put("color", color);
return params;
}
//省去 get / set
}
public class TemplateMsgResult{
private static final long serialVersionUID = 3198012785950215862L;
private int errcode; // 状态
private String errmsg; // 信息
private String msgid; // 消息id(发送模板消息)
}