第一步:获取access_token
第一步详情:因为access_token在微信公众号还是小程序,在一个月之内都有获取次数的限制,并且一个access_token只有2小时的有效期;所以每当我们获取一次access_token,就要反复利用;我这里的方法是将获得access_token存进一个数据表;然后每次先去表中查access_token;判断是否有效,过期则重新在去获取一次,在存到数据表中,更新时间。
下面是我存access_token数据表的结构:
//微信小程序获取access_token function getTokens(){ $appid='你们自己的'; $appsecret='你们自己的'; $mysql = new Mysql(); $info = $mysql->fetchRow("select access_token_time,access_token from wx_account where appid='{$appid}' and appsecret='{$appsecret}'"); $now=time(); if($now-$info['access_token_time']<7000) { $token = $info['access_token']; return $token; } else{ $token_access = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=$appid&secret=$appsecret"; $tokening=curl_get($token_access); $tokens = json_decode($tokening["output"],true); $token =$tokens["access_token"]; $arr = array( 'access_token_time'=>time(), 'access_token'=>$token ); $where = "appid='{$appid}' and appsecret='{$appsecret}'"; $res = $mysql->update($arr,$where,'wx_account'); unset($mysql); if($res) { return $token; } } }
第二步:获取formId
第二步详情:获取小程序端的formid,微信小程序在对表单form进行操作的时候,会产生formid,这个需要自己去获取formid;这个formid是小程序发送模板消息必要参数之一,并且一个formid有效期只有7天,只能够使用一次。下面是我获取formId的存进数据库的数据表:(注意一个在获取formId的同时,也要获取当前的openid);每次使用完formid,这个formid就不能在使用。
第三步:判断获取formId是否过期
第三步详情:formid有一个有效期7天,所以我们要判断你使用的formid是否在有效期内。根据当前时间和createTime字段进行判断。下面是方法,我使用递归的方法,如果在有效期内,返回这个formid;如果不在这个有效期内,则递归调用自身,直至有能够使用的formid。
//判断form_id是否过期 function form($openid) { $mysql = new Mysql(); $formId = $mysql->fetchRow("select * from zacg_formId where openid='{$openid}'and status=0 "); if(empty($formId)) { return false; } $create_time = $formId['createTime']; $now_time = time(); $cha_time = $now_time-($create_time+60*60*24*7); if($cha_time>0) { $data = array( 'status'=> '2' ); $res=$mysql->update($data,"openid='{$openid}' and formId='{$formId["formId"]}'","zacg_formId"); if($res) { unset($mysql); return form($openid); } }else{ unset($mysql); return $formId['formId']; } }
第四步:传递模板数据
第四步详情:发送模板消息,模板的内容需要我们自己去配凑起来,首先要去你的微信公众平台申请一个模板消息,申请成功之后,微信会给你发送一个模板id;例如下图:
//传递模板数据 function data($keyword,$openid,$template_id,$page,$form_id) { $data = array( "touser" => $openid,//推送的人的openid "template_id" => $template_id,//模板id "page" => $page,//跳转路径 "form_id" => $form_id,//form_id "data" => $keyword ); $result = sendpassMessage($data); if($result['output']['errcode']==0) { return true; } else{ return false; } }
第五步:发送模板消息
//发送小程序模板消息 function sendpassMessage($data) { $token = getTokens(); $template = $data; //数组形式的模板内容 $json_template = json_encode($template); $url = "https://api.weixin.qq.com/cgi-bin/message/wxopen/template/send?access_token=".$token; $res = curl_post($url,urldecode($json_template)); //以post方式 向用户发送数据 return $res; }
第六步:接口(群发,循环数据库用户的openid,查找多个formid,然后群发模板消息,可在第四步之前获取数据,进行数据传递)
$keyword1= $activityInfo['title'];//活动主题
$keyword2= $activityInfo['address'];//会议地点
$keyword3= $activityInfo['limitNumber'];//参会人数
$keyword4= date("Y-m-d H:i:s",$activityInfo['startTime']) .'-'. date("Y-m-d H:i:s",$activityInfo['endTime']);//会议时间
$keyword5= "报名截止时间为". date("Y-m-d H:i:s",$activityInfo['deadline']);//温馨提示
$openidArr = $mysql->fetchRows("select openid from zacg_user where companyId={$companyId} and role in ({$role})");
foreach($openidArr as $k=>$v)
{
$openid = "{$v['openid']}";
$template_id = "UwvpxmzzqMBCoHd76ED4cr1GK94ps9584UJC70lXjRY";
$page = "pages/activityList/activityDetails/activityDetails?id=".$activityInfo['id'];
$form_id = form($openid);
$formStatus = array(
'status'=>'1'
);
$keyword = array(
'keyword1'=>array("value" => $keyword1),//活动主题
'keyword2'=>array("value" => $keyword2),//会议地点
'keyword3'=>array("value" => $keyword3),//参会人数
'keyword4'=>array("value" => $keyword4),//会议时间
'keyword5'=>array("value" => $keyword5),//温馨提示
);
$result = data($keyword,$openid,$template_id,$page,$form_id);
$mysql->update($formStatus,"formId='{$form_id}'","zacg_formId");//1表示已经使用
}
注意:以上代码中的sql语句是我所在公司的框架中的写法,需要的换成你们自己的写法即可。
http://www.ahhfit.top/news/1044.html