【黄啊码】PHP配合微信公众号生成推广二维码

举报
黄啊码 发表于 2022/06/29 00:50:06 2022/06/29
【摘要】 前言 为了满足用户渠道推广分析和用户帐号绑定等场景的需要,公众平台提供了生成带参数二维码的接口。使用该接口可以获得多个带不同场景值的二维码,用户扫描后,公众号可以接收到事件推送。 1、目前有2种类型的二维码 临时二维码,是有过期时间的,最长可以设置为在二维码生成后的30天(即2592000秒)后过期,但能够生成较多数量。临时二维...

前言

为了满足用户渠道推广分析和用户帐号绑定等场景的需要,公众平台提供了生成带参数二维码的接口。使用该接口可以获得多个带不同场景值的二维码,用户扫描后,公众号可以接收到事件推送。

1、目前有2种类型的二维码

  • 临时二维码,是有过期时间的,最长可以设置为在二维码生成后的30天(即2592000秒)后过期,但能够生成较多数量。临时二维码主要用于帐号绑定等不要求二维码永久保存的业务场景 

  • 永久二维码,是无过期时间的,但数量较少(目前为最多10万个)。永久二维码主要用于适用于帐号绑定、用户来源统计等场景

2、用户扫描带场景值二维码时,可能推送以下两种事件

  • 如果用户还未关注公众号,则用户可以关注公众号,关注后微信会将带场景值关注事件推送给开发者。

  • 如果用户已经关注公众号,在用户扫描后会自动进入会话,微信也会将带场景值扫描事件推送给开发者。

获取带参数的二维码的过程包括两步,首先创建二维码ticket,然后凭借ticket到指定URL换取二维码。

3、创建二维码ticket

每次创建二维码ticket需要提供一个开发者自行设定的参数(scene_id),分别介绍临时二维码和永久二维码的创建二维码ticket过程。

4、临时二维码请求说明


  
  1. http请求方式: POST
  2. URL: https://api.weixin.qq.com/cgi-bin/qrcode/create?access_token=TOKEN
  3. POST数据格式:json
  4. POST数据例子:{"expire_seconds": 604800, "action_name": "QR_SCENE", "action_info": {"scene": {"scene_id": 123}}}
  5. 或者也可以使用以下POST数据创建字符串形式的二维码参数:
  6. {"expire_seconds": 604800, "action_name": "QR_STR_SCENE", "action_info": {"scene": {"scene_str": "test"}}}

5、永久二维码请求说明


  
  1. http请求方式: POST
  2. URL: https://api.weixin.qq.com/cgi-bin/qrcode/create?access_token=TOKEN
  3. POST数据格式:json
  4. POST数据例子:{"action_name": "QR_LIMIT_SCENE", "action_info": {"scene": {"scene_id": 123}}}
  5. 或者也可以使用以下POST数据创建字符串形式的二维码参数:
  6. {"action_name": "QR_LIMIT_STR_SCENE", "action_info": {"scene": {"scene_str": "test"}}}

6、临时二维码和永久二维码生成实现的代码


  
  1. //临时二维码
  2. public function getQrls()
  3. {
  4. $accessToken = $this->_getWxAccessToken();
  5. $url = "https://api.weixin.qq.com/cgi-bin/qrcode/create?access_token={$accessToken}";
  6. $postArr = [
  7. "action_name" => "QR_SCENE",
  8. "expire_seconds" => 604800,
  9. "action_info" => [
  10. 'scene' => ['scene_id' => 2000],
  11. ],
  12. ];
  13. $postJson = json_encode($postArr);
  14. $res = $this->ch($url, 'post', 'json', $postJson);
  15. $ticket = $res['ticket'];
  16. $url = "https://mp.weixin.qq.com/cgi-bin/showqrcode?ticket=".urlencode($ticket);
  17. echo "<img src='".$url."'>";
  18. }
  19. //永久二维码
  20. public function getQryj()
  21. {
  22. $accessToken = $this->_getWxAccessToken();
  23. $url = "https://api.weixin.qq.com/cgi-bin/qrcode/create?access_token={$accessToken}";
  24. $postArr = [
  25. "action_name" => "QR_LIMIT_SCENE",
  26. "action_info" => [
  27. 'scene' => ['scene_id' => 3000],
  28. ],
  29. ];
  30. $postJson = json_encode($postArr);
  31. $res = $this->ch($url, 'post', 'json', $postJson);
  32. $ticket = $res['ticket'];
  33. $url = "https://mp.weixin.qq.com/cgi-bin/showqrcode?ticket=".urlencode($ticket);
  34. echo "<img src='".$url."'>";
  35. }
  36. //url请求
  37. private function ch($url, $type='get', $res='json', $arr='')
  38. {
  39. $ch = curl_init();
  40. curl_setopt($ch, CURLOPT_URL, $url);
  41. curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
  42. curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE);
  43. curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE);
  44. if ($type == 'post') {
  45. curl_setopt($ch, CURLOPT_POST, 1);
  46. curl_setopt($ch, CURLOPT_POSTFIELDS, $arr);
  47. }
  48. $cnt = curl_exec($ch);
  49. if (curl_errno($ch)) {
  50. return;
  51. }
  52. curl_close($ch);
  53. if ($res == 'json') {
  54. return json_decode($cnt, true);
  55. }
  56. return $cnt;
  57. }

生成临时、永久二维码的图片这里就不放了,感兴趣的可以自己运行一下哈。

文章来源: markwcm.blog.csdn.net,作者:黄啊码,版权归原作者所有,如需转载,请联系作者。

原文链接:markwcm.blog.csdn.net/article/details/124922970

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。