微信推送模板消息的PHP代码整理

最近做过一个需要推送消息的系统,就研究了一下微信的模板消息的推送。由于认证过的微信号,就用测试号做的,但是过程基本一致。

微信推送模板消息的PHP代码整理

本文基于微信平台的官方文档写成,http://mp.weixin.qq.com/debug/cgi-bin/readtmpl?t=tmplmsg/faq_tmpl

首先,得在微信的后台管理中设置一下,模板消息的格式,获取到一个模板消息的id


  1. {{first.DATA}}  
  2. 被撕的人:{{name.DATA}}  
  3. 被撕人的组别:{{zu.DATA}}  
  4. 被撕时间:{{time.DATA}}  
  5. 本组剩余的人:{{remain.DATA}} 
  6. {{remark.DATA}} 

这里以做的一个撕名牌的通知为例,相关参数的设置如上。生成id备用。

下面直接贴出需要调用的函数moban()  和它的辅助函数http_request()


  1. http_request(){ 
  2. $ch = curl_init(); 
  3. curl_setopt($ch, CURLOPT_URL, $url); 
  4. curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); 
  5. curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE); 
  6. curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE); 
  7. curl_setopt($ch, CURLOPT_POST, 1); 
  8. curl_setopt($ch, CURLOPT_POSTFIELDS, $data); 
  9. $output = curl_exec($ch); 
  10. curl_close($ch); 
  11. return $output
  12.  
  13.   function moban($name,$zu,$remain,$openid
  14.   { 
  15.  
  16.  $appid="";       //填写微信后台的appid 
  17.  $appsecret="";   //填写微信后台的appsecret 
  18.  //从数据库查看access_token 
  19.               $sql="SELECT * FROM `tokentime` WHERE id='$appid'"
  20.               $query=mysql_query($sql); 
  21.               $rk=mysql_fetch_array($query); 
  22.               $time=date('Y-m-d H:i:s',time()); 
  23.               if($rk=="")   //数据库查询无结果 获取access_token并存入 
  24.               { 
  25.                     
  26.                    $TOKEN_URL="https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=".$appid."&secret=".$appsecret
  27.                    $json=file_get_contents($TOKEN_URL); 
  28.                    $result=json_decode($json,true); 
  29.                    $ACCESS_TOKEN=$result['access_token'];   
  30.                   
  31.                    $sql1="INSERT INTO `tokentime` (`id`,`access_token`,`time`) VALUES ('$appid','$ACCESS_TOKEN','$time')"
  32.                    $query1=mysql_query($sql1); 
  33.             } 
  34.               else 
  35.               {   $time_b=$rk['time'];//上次存的时间 
  36.                   $time_n=date('Y-m-d H:i:s',time()-7200); 
  37.                      
  38.                   if($rk['access_token']==""||$time_b<$time_n
  39.                   { 
  40.                     $TOKEN_URL="https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=".$appid."&secret=".$appsecret
  41.                    $json=file_get_contents($TOKEN_URL); 
  42.                    $result=json_decode($json,true); 
  43.                    $ACCESS_TOKEN=$result['access_token'];   
  44.                   
  45.                    $sql2="UPDATE tokentime SET access_token='$ACCESS_TOKEN',time='$time' WHERE id='$appid'"
  46.                    $query2=mysql_query($sql2);         
  47.                 } 
  48.                   else 
  49.                   { 
  50.                      $ACCESS_TOKEN=$rk['access_token'];  
  51.                   } 
  52.                 } 
  53. //模板消息     
  54.    $timesdate('m月d日 H:i:s',time());   
  55.        
  56. $template=array
  57. 'touser'=>$openid
  58. 'template_id'=>"_0DQerSIqPZaB4vjQjjOIPRXZhcVooFT_390vDhHhVw",    //模板的id 
  59. 'url'=>"http://weixin.qq.com/download"
  60. 'topcolor'=>"#FF0000"
  61. 'data'=>array
  62. 'name'=>array('value'=>urlencode($name),'color'=>"#00008B"),    //函数传参过来的name      
  63. 'zu'=>array('value'=>urlencode($zu),'color'=>'#00008B'),        //函数传参过来的zu 
  64. 'time'=>array('value'=>urlencode($times),'color'=>'#00008B'),   //时间 
  65. 'remain'=>array('value'=>urlencode($remain),'color'=>'#00008B'),//函数传参过来的ramain 
  66. ); 
  67. $json_template=json_encode($template); 
  68. $url="https://api.weixin.qq.com/cgi-bin/message/template/send?access_token=".$ACCESS_TOKEN
  69. $res=http_request($url,urldecode($json_template)); 
  70. if ($res[errcode]==0) echo '消息发送成功!';  

函数的调用需要注意几点

 1、moban()函数是需要传参的,具体传参的

moban($name,$zu,$remain,$openid)   
$name 被撕的人
$zu 被撕的人组别
$remain 本组剩余的人
$openid 发送给哪个openid
传参的可以自行修改 只需要对应上函数里面模板的输出格式
模板里面的appid appserect一定要填

2、数据库的一定在要在数据库里面建一个表,因为access_token的有效期只有7200s,防止它过期这里采用了数据库保存的方式,表名为tokentime,三个字段就可以了,分别是id(int) time(varchar) access_token(varchar) //括号里面是格式,access_token字段一定要大一点

至此就可以使用自己的模板给用户发消息了,由于发送模板消息是按照openid发送的,所有需要获取用户的openid。
等有时间,写一下如何批量获取用户的openid,存入数据库,并发送模板消息和其他操作。
 



作者:深秋雨滴

来源:51CTO

上一篇:IOS调用系统通讯录


下一篇:Facebook将在印度推出2万个WiFi热点 这是个什么项目?