一、添加消息模板
1、所有服務號都可以在功能->添加功能插件處看到申請模板消息功能的入口,但只有認證后的服務號才可以申請模板消息的使用權限並獲得該權限;
2、需要選擇公眾賬號服務所處的2個行業
3、在所選擇行業的模板庫中添加模板;
4、在我的模板中可以看到添加的模板(商家新訂單提醒模板)

二、模板消息接口開發
access_token是公眾號的全局唯一票據,公眾號調用各接口時都需使用access_token,access_token的有效期是2小時。
模板消息需要使用access_token來授權。
1、獲取access_token
接口地址:https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=APPID&secret=APPSECRET
請求方式:GET
返回的數據格式:json格式
1 public String getAccessToken(){ 2 String requestUrl = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=APPID&secret=APPSECRET"; 3 4 String appid = "appid";//第三方用戶唯一憑證 5 6 String secret = "appsecret";// 第三方用戶唯一憑證密鑰,即appsecret 7 8 requestUrl=requestUrl.replace("APPID", appid); 9 requestUrl=requestUrl.replace("APPSECRET", secret); 10 11 JSONObject jsonObject= CommonUtil.httpsRequestToJsonObject(requestUrl, "GET", null, false); 12 13 String access_token = jsonObject.getString("access_token"); 14 15 return access_token; 16 17 }
2、模板
1 public class Template { 2 3 // 消息接收方 4 private String toUser; 5 // 模板id 6 private String templateId; 7 // 模板消息詳情鏈接 8 private String url; 9 // 消息頂部的顏色 10 private String topColor; 11 // 參數列表 12 private List<TemplateParam> templateParamList; 13 //省略getter、setter方法 14 15 //按微信接口要求格式化模板 16 public String toJSON() { 17 StringBuffer buffer = new StringBuffer(); 18 buffer.append("{"); 19 buffer.append(String.format("\"touser\":\"%s\"", this.toUser)).append(","); 20 buffer.append(String.format("\"template_id\":\"%s\"", this.templateId)).append(","); 21 buffer.append(String.format("\"url\":\"%s\"", this.url)).append(","); 22 buffer.append(String.format("\"topcolor\":\"%s\"", this.topColor)).append(","); 23 buffer.append("\"data\":{"); 24 TemplateParam param = null; 25 for (int i = 0; i < this.templateParamList.size(); i++) { 26 param = templateParamList.get(i); 27 // 判斷是否追加逗號 28 if (i < this.templateParamList.size() - 1){ 29 30 buffer.append(String.format("\"%s\": {\"value\":\"%s\",\"color\":\"%s\"},", param.getName(), param.getValue(), param.getColor())); 31 }else{ 32 buffer.append(String.format("\"%s\": {\"value\":\"%s\",\"color\":\"%s\"}", param.getName(), param.getValue(), param.getColor())); 33 } 34 35 } 36 buffer.append("}"); 37 buffer.append("}"); 38 return buffer.toString(); 39 } 40 }
3、發送模板消息,返回json格式結果
public JSONObject sendTemplateMsg(Template template){ //獲取token String token = accessTokenService.getAccessToken(); String requestUrl = "https://api.weixin.qq.com/cgi-bin/template/api_add_template?access_token=ACCESS_TOKEN"; requestUrl=requestUrl.replace("ACCESS_TOKEN", token); if (log.isDebugEnabled()) { log.debug(template.toJSON()); } //發送模板消息,返回json格式結果 JSONObject jsonObject = CommonUtil.httpsRequestToJsonObject(requestUrl, "POST", template.toJSON(),false); return jsonObject; }
三、實現效果
以訂單支付成功通知為例:
構造消息實體:
1 String tplId = "whmJQfErBz_62Fu4ebCiDkz4u9hgBJOMolbLEwZDvh4"; 2 Template tem=new Template(); 3 tem.setTemplateId(tplId); 4 tem.setTopColor(SUCCESS_TOP_COLOR); 5 6 List<TemplateParam> paras=new ArrayList<TemplateParam>(); 7 paras.add(new TemplateParam("first","您有一筆新訂單,等待發貨。","#333")); 8 paras.add(new TemplateParam("keyword1","T16081000152","#333")); 9 paras.add(new TemplateParam("keyword2","白菜套餐*1","#333")); 10 paras.add(new TemplateParam("keyword3","9.00元","#333")); 11 paras.add(new TemplateParam("keyword4","余額支付","#333")); 12 paras.add(new TemplateParam("keyword5","零零壹、12345678901","#333")); 13 paras.add(new TemplateParam("remark","請及時處理,感謝你對雲農批的支持!!!","#333")); 14 15 tem.setTemplateParamList(paras); 16 tem.setToUser("openid");//用戶openid 17 //設置超鏈接 18 tem.setUrl(WeixinConfig.getInstance().getYnp_url()); 19 20 21 JSONObject jsonObject = sendTemplateMsg(tem);
實現效果:

