PHP實(shí)現(xiàn)小程序批量通知推送
本文實(shí)例為大家分享了PHP實(shí)現(xiàn)小程序批量通知推送的具體代碼,供大家參考,具體內(nèi)容如下
基本效果如下:
具體實(shí)現(xiàn)如下:
1.配置模板
2.從小程序獲取formId,傳到后臺存到表里
下發(fā)條件說明
1).支付
當(dāng)用戶在小程序內(nèi)完成過支付行為,可允許開發(fā)者向用戶在7天內(nèi)推送有限條數(shù)的模板消息(1次支付可下發(fā)3條,多次支付下發(fā)條數(shù)獨(dú)立,互相不影響)
2).提交表單
當(dāng)用戶在小程序內(nèi)發(fā)生過提交表單行為且該表單聲明為要發(fā)模板消息的,開發(fā)者需要向用戶提供服務(wù)時,可允許開發(fā)者向用戶在7天內(nèi)推送有限條數(shù)的模板消息(1次提交表單可下發(fā)1條,多次提交下發(fā)條數(shù)獨(dú)立,相互不影響)
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后臺實(shí)現(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.跳轉(zhuǎn)地址,你知道的 $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 需要設(shè)置為 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"=> "跳轉(zhuǎn)地址", "form_id"=> $formid, "data"=> array( "keyword1"=> array( "value"=> $title ), "keyword2"=> array( "value"=> $time ), "keyword3"=> array( "value"=> "戳我進(jìn)入涂呀首頁查看" )), // "emphasis_keyword"=> "keyword1.DATA" 設(shè)置大字,自己試試就知道了 ); $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;
文檔:地址
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
深入探討:Nginx 502 Bad Gateway錯誤的解決方法
本篇文章是對Nginx 502 Bad Gateway錯誤的解決方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06PHP隊列場景以及實(shí)現(xiàn)代碼實(shí)例詳解
這篇文章主要介紹了PHP隊列場景以及實(shí)現(xiàn)代碼實(shí)例詳解,有感興趣的同學(xué)可以跟著學(xué)習(xí)研究下2021-02-02PHP中exec函數(shù)和shell_exec函數(shù)的區(qū)別
這篇文章主要介紹了PHP中exec函數(shù)和shell_exec函數(shù)的區(qū)別,這兩個函數(shù)是非常危險的函數(shù),一般情況都是被禁用的,當(dāng)然特殊情況下也會使用,需要的朋友可以參考下2014-08-08PHP與jquery實(shí)時顯示網(wǎng)站在線人數(shù)實(shí)例詳解
在線人數(shù)最簡單的就是直接利用js調(diào)用php了,這樣可以顯示出有多少人訪問了本站,如果要在用戶未刷新頁面的狀態(tài)實(shí)時顯示用戶在線人數(shù),我們可以利用jquery ajax來實(shí)現(xiàn),需要的朋友可以參考下2016-12-12PHP getallheaders無法獲取自定義頭(headers)的問題
這篇文章主要介紹了PHP getallheaders無法獲取自定義頭(headers)的問題的相關(guān)資料,需要的朋友可以參考下2016-03-03詳解laravel passport OAuth2.0的4種模式
這篇文章主要介紹了laravel passport OAuth2.0的4種模式,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下2019-11-11