场景参数的⼆维码⽣成与使⽤
应⽤场景:推⼴时,⽤户通过扫码关注,需要统计⽤户是通过谁的⼆维码进⾏关注。
思路:在⽤户扫码关注时,⼆维码带上推⼴者的id,在关注后,获取到该推⼴者的id。
⽬前有2种类型的⼆维码:
1、临时⼆维码,是有过期时间的,最长可以设置为在⼆维码⽣成后的30天(即2592000秒)后过期,但能够⽣成较多数量。临时⼆维码主要⽤于帐号绑定等不要求⼆维码永久保存的业务场景
2、永久⼆维码,是⽆过期时间的,但数量较少(⽬前为最多10万个)。永久⼆维码主要⽤于适⽤于帐号绑定、⽤户来源统计等场景。
这⾥我们选择永久⼆维码来实现功能。
⾸先我们先创建并获取到带有推⼴者id的⼆维码。
1.创建⼆维码ticket,每次创建⼆维码ticket需要提供⼀个开发者⾃⾏设定的参数(scene_id),这个scene_id也就是推⼴者的id
或者也可以使⽤以下POST数据创建字符串形式的⼆维码参数:
{“action_name”: “QR_LIMIT_STR_SCENE”, “action_info”: {“scene”: {“scene_str”: “test”}}}
因为我们带的是推⼴者的id,所以我们选⽤前⾯⼀种带整型的参数。
参数说明:
action_name :⼆维码类型,QR_LIMIT_SCENE为永久的整型参数值
action_info ⼆维码详细信息
scene_id 场景值ID,临时⼆维码时为32位⾮0整型,永久⼆维码时最⼤值为100000(⽬前参数只⽀持1–100000)
1.1 通过AppID以及AppSecret获取access_token
public function access_token() {
try{
$token = Db::name('access_token')->where('id',2)->find();
if ($token['time']<time()) {
佐助vs团藏是第几集
$url    = 'api.weixin.qq/cgi-bin/token?grant_type=client_credential&appid=wxf9f65c0fd755d6db&secret=9b62ba0fcb44143f0111b58fa02e813e';
$token  = curl1('get', $url);
$token  = json_decode($token, true);
国宝大熊猫作文三年级350字Db::name('access_token')->where('id',2)->update([
'token' => $token['access_token'],
'time'  => bcadd(time(), 7200)
]);
}else{
$token  = $token['token'];
电动车批发市场}
return$token;
}catch (\Exception$e){
echo$e->getMessage();
}
霍建华林心如恋情曝光
}
根据access_token请求链接获取ticket,这⾥scene_id为整数,scene_str为字符串,  可根据实际情况改变
/**
* ⽣成⼆维码所需要的ticket
* 2021/5/22 13:47
*/
public function get_ticket() {
$token = $this->access_token();
$state = time().$this->two_letter(11);
$url = 'api.weixin.qq/cgi-bin/qrcode/create?access_token='.$token;
$data['data'] = json_encode([
'expire_seconds'    => 60,
'action_name'      => 'QR_LIMIT_STR_SCENE',
'action_info'      => [
'scene'    =>  [
'scene_str' => $state
贾玲的妈妈]
]
]
);
$ticket = curl1('post', $url, $data);
$ticket = json_decode($ticket, true);
return json_encode(['ticket'=>$ticket['ticket'], 'state'=>$state]);
}
⾸先,我们要知道⽤户扫描带场景值⼆维码时,可能推送以下两种事件
如果⽤户还未关注,则⽤户可以关注,关注后会将带场景值关注事件推送给开发者。
如果⽤户已经关注,在⽤户扫描后会⾃动进⼊会话,也会将带场景值扫描事件推送给开发者。
这些所谓的事件推送给开发者其实就是返回⼀个xml数据包给开发者,所以现在最⼤的问题就是如何接收到这个xml数据包。
我们登录公众平台,开发- - 基本配置
从这⾥我们可以知道,开发者需要的事件推送将会被转发到我们设置的服务器地址中。protected$token = '基本配置分配的token';
//校验
public function check() {
//从GET参数中读取三个字段的值
$signature = $_GET["signature"];
$timestamp = $_GET["timestamp"];
$nonce = $_GET["nonce"];
//读取预定义的TOKEN
$token = $this->token;
//对数组进⾏排序
$tmpArr = array($token, $timestamp, $nonce);
sort($tmpArr, SORT_STRING);
//对三个字段进⾏sha1运算
$tmpStr = implode($tmpArr);
$tmpStr = sha1($tmpStr);
//判断我⽅计算的结果是否和端计算的结果相符
//这样利⽤只有端和我⽅了解的token作对⽐,验证访问是否来⾃官⽅.
if ($tmpStr == $signature && $_GET["echostr"]) {
echo$_GET["echostr"];
exit;
} else {
$this->reponseMsg();
}
}
/**
* 接收推送消息
* 2021/5/24 15:36
*/
public function reponseMsg() {
$redis = new_redis();
$postStr = file_get_contents('php://input');    //获取到xml数据包
$postObj = simplexml_load_string($postStr);//转化成对象
switch ($postObj->MsgType) {
case 'event':
//推送事件
if($postObj->Event == 'subscribe'){
//这⾥是扫描⼆维码事件
//⽤户未关注的情况
$openid = $postObj->FromUserName; //这⾥是⽤户的openid
$str = $postObj->EventKey;
//qrscene_123123  ⽤户未关注的情况下KEY值: qrscene_为前缀,后⾯为⼆维码的参数值
$arr    = explode('_', $str);
$state  = end($arr);    //这⾥是state, redis的前缀
/
/剩下的代码就省略了, 根据实际需求来实现不同的功能.
$redis->set($state, $openid); //我这⾥是吧openid 存到redis⾥了
}else if($postObj->Event == 'SCAN'){
//这⾥是扫描⼆维码事件
//⽤户关注的情况
$openid = $postObj->FromUserName; //这⾥是⽤户的openid
$state = $postObj->EventKey;  //这⾥是推⼴者的id
//剩下的代码就省略了, 根据实际需求来实现不同的功能.
$redis->set($state, $openid);
}
break;
周冬雨探班马思纯default:
$this->err('推送失败');
break;
}
}