在这篇微信公众平台开发教程中,我们将介绍如何开发模板消息,即如何用程序发送模板消息功能。
本文分为以下三个部分:
一、申请模板消息权限
模板消息的申请需账号已经开通微信支付权限。
在微信公众平台的后台,依次进入“功能->添加功能插件->模板消息”,即可申请模板消息。
点击申请
申请时,选择2个和自己相关的行业即可。
提交并且申请通过后,可以在模板库中看到模板消息列表
进入想要使用的模板,点击添加
添加后就存放到“我的模板库”中了
查看模板的详情,可以看到模板的id及各项内容参数名
不同的模板消息的内容结构不一样。这些id及字段名将在程序中使用到。
二、开发模板消息SDK
模板消息的定义如下:
模板消息也是使用access token作为授权来发送。
我们在微信公众平台高级SDK的基本上,稍加修改即可。模板消息的SDK实现如下
<?php namespace commonextensionsweixin; use Yii; class weixin{ public $appid = ''; public $appsecret = ''; public $access_token = null; function __construct(){ $this->appid = 'xxxxxxxxxxxxxx'; $this->appsecret = 'xxxxxxxxxxxxx'; } /** * 获取微信基础接口凭证Access_token * @param $refresh 强制刷新, 默认false * @return String */ public function getAccess_token($refresh = false) { $data = json_decode(file_get_contents(Yii::getAlias('@common').'/extensions/weixin/access_token.json')); if ( $data->expire_time < time() || $refresh ) { $url = 'https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid='.$this->appid.'&secret='.$this->appsecret; $result = json_decode(file_get_contents($url)); $access_token = isset($result->access_token) ? $result->access_token : ''; if (isset($result->errcode) && !$access_token) { // $this->error('get access_token failed.'); } else { $data->expire_time = time() + 7000; $data->access_token = $access_token; $fp = fopen(Yii::getAlias('@common').'/extensions/weixin/access_token.json', "w"); fwrite($fp, json_encode($data)); fclose($fp); $this->access_token = $access_token; } } else { $this->access_token = $data->access_token; } return $this->access_token; } //发送模板消息 public function send_template_message($data) { $url = 'https://api.weixin.qq.com/cgi-bin/message/template/send?access_token=' . $this->getAccess_token(true); $result = $this->http_request($url, urldecode(json_encode($data))); return json_decode($result, true); } // 发送 protected function http_request($url, $data = null) { $curl = curl_init(); curl_setopt($curl, CURLOPT_URL, $url); curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, FALSE); curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, FALSE); if (!empty($data)) { curl_setopt($curl, CURLOPT_POST, 1); curl_setopt($curl, CURLOPT_POSTFIELDS, $data); } curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1); $output = curl_exec($curl); curl_close($curl); return $output; } }
三、构造模板消息体
我们以一个预警监控模板为例,它的内容如下。
调用sdk发送内容