PHP實現(xiàn)小程序批量通知推送
本文實例為大家分享了PHP實現(xiàn)小程序批量通知推送的具體代碼,供大家參考,具體內容如下
基本效果如下:


具體實現(xiàn)如下:
1.配置模板

2.從小程序獲取formId,傳到后臺存到表里
下發(fā)條件說明
1).支付
當用戶在小程序內完成過支付行為,可允許開發(fā)者向用戶在7天內推送有限條數(shù)的模板消息(1次支付可下發(fā)3條,多次支付下發(fā)條數(shù)獨立,互相不影響)
2).提交表單
當用戶在小程序內發(fā)生過提交表單行為且該表單聲明為要發(fā)模板消息的,開發(fā)者需要向用戶提供服務時,可允許開發(fā)者向用戶在7天內推送有限條數(shù)的模板消息(1次提交表單可下發(fā)1條,多次提交下發(fā)條數(shù)獨立,相互不影響)
wxml
<form bindsubmit="getFormId" report-submit="true"> <button formType='submit'>獲取formId</button> </form>
js
getFormId:function(e){
let formId = e.detail.formId;
//得到formId,將formId傳到后臺存儲到表里
}
我的表是這么建的:
createTime用來判斷是否超過七天
used用來判斷是否使用過這個formId

3.PHP后臺實現(xiàn)推送
一共使用兩個提供的api
1).獲取小程序 access_token
請求地址
GET https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=APPID&secret=APPSECRET
2).發(fā)送模板消息
請求地址
POST https://api.weixin.qq.com/cgi-bin/message/wxopen/template/send?access_token=ACCESS_TOKEN
php完整代碼:
//需要修改的字段
//1.小程序AppId,小程序secret,去微信公眾平臺找
//2.表名,時間字段
//3.模板ID,去我的模板里找
//4.跳轉地址,你知道的
$url = 'https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=小程序AppId&secret=小程序secret';
$info = file_get_contents($url);
$json = json_decode($info);/*對json數(shù)據(jù)解碼*/
$arr = get_object_vars($json);
$access_token = $arr['access_token'];
function send_post( $url, $post_data ) {
$options = array(
'http' => array(
'method' => 'POST',
'header' => 'Content-type:application/json',/*header 需要設置為 JSON*/
'content' => $post_data,
'timeout' => 60/*超時時間*/
)
);
$context = stream_context_create( $options );
$result = file_get_contents( $url, false, $context );
return $result;
};
$sql = "SELECT * FROM 表名 where date_sub(curdate(), INTERVAL 6 DAY) <= date(時間字段) and used=0 group by openid";
$rs = $pdo->query($sql);
$row = $rs->fetchAll();
$resultsArr = array();
$updateArr = array();
$successNum = 0;
$title = $_GET['title'];
$time = date('y年m月d日 h:i',time());
for($i=0;$i<count($row);$i++){
$openid = $row[$i]['openid'];
$formid = $row[$i]['formId'];
$id = $row[$i]['id'];
$post_data = array(
"touser"=> $openid,
"template_id"=> "模板ID",
"page"=> "跳轉地址",
"form_id"=> $formid,
"data"=> array(
"keyword1"=> array(
"value"=> $title
),
"keyword2"=> array(
"value"=> $time
),
"keyword3"=> array(
"value"=> "戳我進入涂呀首頁查看"
)),
// "emphasis_keyword"=> "keyword1.DATA" 設置大字,自己試試就知道了
);
$post_data = json_encode($post_data);
$postResults = send_post('https://api.weixin.qq.com/cgi-bin/message/wxopen/template/send?access_token='.$access_token, $post_data);
$res = json_decode($postResults);
$res = get_object_vars($res);
$errcode = $res['errcode'];
if($errcode==0){
$sql1 = "update formIdList set used=1 where id=$id";
$pdo->exec($sql1);
$successNum+=1;
};
array_push($resultsArr, array('errcode'=>$errcode));
};
$Results = array(
'code'=>1,
'Results'=>array(
'successNum'=>$successNum,
'resultsArr'=>$resultsArr
),
'msg'=>''
);
$Results = json_encode($Results);
echo $Results;
文檔:地址
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
深入探討:Nginx 502 Bad Gateway錯誤的解決方法
本篇文章是對Nginx 502 Bad Gateway錯誤的解決方法進行了詳細的分析介紹,需要的朋友參考下2013-06-06
PHP中exec函數(shù)和shell_exec函數(shù)的區(qū)別
這篇文章主要介紹了PHP中exec函數(shù)和shell_exec函數(shù)的區(qū)別,這兩個函數(shù)是非常危險的函數(shù),一般情況都是被禁用的,當然特殊情況下也會使用,需要的朋友可以參考下2014-08-08
PHP與jquery實時顯示網(wǎng)站在線人數(shù)實例詳解
在線人數(shù)最簡單的就是直接利用js調用php了,這樣可以顯示出有多少人訪問了本站,如果要在用戶未刷新頁面的狀態(tài)實時顯示用戶在線人數(shù),我們可以利用jquery ajax來實現(xiàn),需要的朋友可以參考下2016-12-12
PHP getallheaders無法獲取自定義頭(headers)的問題
這篇文章主要介紹了PHP getallheaders無法獲取自定義頭(headers)的問題的相關資料,需要的朋友可以參考下2016-03-03
詳解laravel passport OAuth2.0的4種模式
這篇文章主要介紹了laravel passport OAuth2.0的4種模式,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2019-11-11

