亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

PHP實(shí)現(xiàn)小程序批量通知推送

 更新時(shí)間:2018年11月27日 15:28:08   作者:孫智斌  
這篇文章主要為大家詳細(xì)介紹了PHP實(shí)現(xiàn)小程序批量通知推送,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

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

基本效果如下:

具體實(shí)現(xiàn)如下:

1.配置模板

2.從小程序獲取formId,傳到后臺(tái)存到表里

下發(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ù)時(shí),可允許開發(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傳到后臺(tái)存儲(chǔ)到表里
}

我的表是這么建的:

createTime用來判斷是否超過七天
used用來判斷是否使用過這個(gè)formId

3.PHP后臺(tái)實(shí)現(xiàn)推送

一共使用兩個(gè)提供的api

1).獲取小程序 access_token

請(qǐng)求地址

GET https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=APPID&secret=APPSECRET

2).發(fā)送模板消息

請(qǐng)求地址

POST https://api.weixin.qq.com/cgi-bin/message/wxopen/template/send?access_token=ACCESS_TOKEN

php完整代碼:

//需要修改的字段
//1.小程序AppId,小程序secret,去微信公眾平臺(tái)找
//2.表名,時(shí)間字段
//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);/*對(duì)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/*超時(shí)時(shí)間*/
    )
   );
   $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(時(shí)間字段) 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)入涂呀首頁(yè)查看"
     )),
   // "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;

文檔:地址

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 深入探討:Nginx 502 Bad Gateway錯(cuò)誤的解決方法

    深入探討:Nginx 502 Bad Gateway錯(cuò)誤的解決方法

    本篇文章是對(duì)Nginx 502 Bad Gateway錯(cuò)誤的解決方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-06-06
  • PHP隊(duì)列場(chǎng)景以及實(shí)現(xiàn)代碼實(shí)例詳解

    PHP隊(duì)列場(chǎng)景以及實(shí)現(xiàn)代碼實(shí)例詳解

    這篇文章主要介紹了PHP隊(duì)列場(chǎng)景以及實(shí)現(xiàn)代碼實(shí)例詳解,有感興趣的同學(xué)可以跟著學(xué)習(xí)研究下
    2021-02-02
  • PHP中exec函數(shù)和shell_exec函數(shù)的區(qū)別

    PHP中exec函數(shù)和shell_exec函數(shù)的區(qū)別

    這篇文章主要介紹了PHP中exec函數(shù)和shell_exec函數(shù)的區(qū)別,這兩個(gè)函數(shù)是非常危險(xiǎn)的函數(shù),一般情況都是被禁用的,當(dāng)然特殊情況下也會(huì)使用,需要的朋友可以參考下
    2014-08-08
  • PHP與jquery實(shí)時(shí)顯示網(wǎng)站在線人數(shù)實(shí)例詳解

    PHP與jquery實(shí)時(shí)顯示網(wǎng)站在線人數(shù)實(shí)例詳解

    在線人數(shù)最簡(jiǎn)單的就是直接利用js調(diào)用php了,這樣可以顯示出有多少人訪問了本站,如果要在用戶未刷新頁(yè)面的狀態(tài)實(shí)時(shí)顯示用戶在線人數(shù),我們可以利用jquery ajax來實(shí)現(xiàn),需要的朋友可以參考下
    2016-12-12
  • PHP getallheaders無法獲取自定義頭(headers)的問題

    PHP getallheaders無法獲取自定義頭(headers)的問題

    這篇文章主要介紹了PHP getallheaders無法獲取自定義頭(headers)的問題的相關(guān)資料,需要的朋友可以參考下
    2016-03-03
  • 詳解laravel passport OAuth2.0的4種模式

    詳解laravel passport OAuth2.0的4種模式

    這篇文章主要介紹了laravel passport OAuth2.0的4種模式,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-11-11
  • 詳解PHP的Sodium加密擴(kuò)展函數(shù)

    詳解PHP的Sodium加密擴(kuò)展函數(shù)

    Sodium 出現(xiàn)的目的也是為了代替Mcrypt這個(gè)原來的加密擴(kuò)展。在 PHP7.2 之后,Mcrypt已經(jīng)被移除,在PHP7.1時(shí)就已經(jīng)被標(biāo)記為過時(shí)。不過,Sodium擴(kuò)展的應(yīng)用也并不是很多,大部分情況下我們都會(huì)使用OpenSSL來進(jìn)行加密操作,所以,我們這篇文章只做了解即可。
    2021-06-06
  • laravel 5 實(shí)現(xiàn)模板主題功能

    laravel 5 實(shí)現(xiàn)模板主題功能

    很多cms里都有模板主題功能,我們可以通過一個(gè)配置切換主題,這個(gè)功能在laravel下如何實(shí)現(xiàn)呢?今天我們就來探討下這個(gè)問題。
    2015-03-03
  • PHP縮略圖生成和圖片水印制作

    PHP縮略圖生成和圖片水印制作

    這篇文章主要為大家詳細(xì)介紹了PHP縮略圖生成和圖片水印制作過程,php實(shí)現(xiàn)水印添加與縮略圖生成的相關(guān)步驟,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-01-01
  • [PHP]實(shí)用函數(shù)3

    [PHP]實(shí)用函數(shù)3

    [PHP]實(shí)用函數(shù)3...
    2007-11-11

最新評(píng)論