在这篇微信公众平台开发教程中,我们将介绍如何开发模板消息,即如何用程序发送模板消息功能。
本文分为以下三个部分:
一、申请模板消息权限
模板消息的申请需账号已经开通微信支付权限。
在微信公众平台的后台,依次进入“功能->添加功能插件->模板消息”,即可申请模板消息。
点击申请
申请时,选择2个和自己相关的行业即可。
提交并且申请通过后,可以在模板库中看到模板消息列表
进入想要使用的模板,点击添加
添加后就存放到“我的模板库”中了
查看模板的详情,可以看到模板的id及各项内容参数名
不同的模板消息的内容结构不一样。这些id及字段名将在程序中使用到。
二、开发模板消息SDK
模板消息的定义如下:
模板消息也是使用access token作为授权来发送。
我们在微信公众平台高级SDK的基本上,稍加修改即可。模板消息的SDK实现如下
<?php
namespace common\extensions\weixin;
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发送内容