第一步:获取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语句是我所在公司的框架中的写法,需要的换成你们自己的写法即可。