微平台开发之生成带参数二维码

来源:互联网 发布:淘宝上的内衣有图评论 编辑:程序博客网 时间:2024/04/30 20:14
一、场景二维码

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

目前有2种类型的二维码,分别是临时二维码和永久二维码,前者有过期时间,最大为1800秒,但能够生成较多数量,后者无过期时间,数量较少(目前参数只支持1--100000)。两种二维码分别适用于帐号绑定、用户来源统计等场景。

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

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

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

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

二、创建二维码ticket

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

临时二维码请求说明

http请求URL

https://api.weixin.qq.com/cgi-bin/qrcode/create?access_token=TOKEN

POST数据格式

1 {2     "expire_seconds": 1800,3     "action_name": "QR_SCENE",4     "action_info": {5         "scene": {6             "scene_id": 1000007         }8     }9 }

返回格式:

{    "ticket": "gQFK8DoAAAAAAAAAASxodHRwOi8vd2VpeGluLnFxLmNvbS9xL3kweXE0T3JscWY3UTltc3ZPMklvAAIEG9jUUgMECAcAAA==",    "expire_seconds": 1800}

永久二维码请求说明

http请求URL

https://api.weixin.qq.com/cgi-bin/qrcode/create?access_token=TOKEN

POST数据格式

{    "action_name": "QR_LIMIT_SCENE",    "action_info": {        "scene": {            "scene_id": 1000        }    }}

返回格式

{    "ticket": "gQHi8DoAAAAAAAAAASxodHRwOi8vd2VpeGluLnFxLmNvbS9xL0UweTNxNi1sdlA3RklyRnNKbUFvAAIELdnUUgMEAAAAAA=="}

提交数据参数说明:

\

返回结果参数说明

\

程序实现

 1 $access_token = " xDx0pD_ZvXkHM3oeu5oGjDt1_9HxlA-9g0vtR6MZ-v4r7MpvZYC4ee4OxN97Lr4irkPKE94tzBUhpZG_OvqAC3D3XaWJIGIn0eeIZnfaofO1C3LNzGphd_rEv3pIimsW9lO-4FOw6D44T3sNsQ5yXQ"; 2   3 //临时 4 $qrcode = '{"expire_seconds": 1800, "action_name": "QR_SCENE", "action_info": {"scene": {"scene_id": 10000}}}'; 5 //永久 6 $qrcode = '{"action_name": "QR_LIMIT_SCENE", "action_info": {"scene": {"scene_id": 1000}}}'; 7   8 $url = "https://api.weixin.qq.com/cgi-bin/qrcode/create?access_token=$access_token"; 9 $result = https_post($url,$qrcode);10 $jsoninfo = json_decode($result, true);11 $ticket = $jsoninfo["ticket"];12  13 function https_post($url, $data = null){14     $curl = curl_init();15     curl_setopt($curl, CURLOPT_URL, $url);16     curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, FALSE);17     curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, FALSE);18     if (!empty($data)){19         curl_setopt($curl, CURLOPT_POST, 1);20         curl_setopt($curl, CURLOPT_POSTFIELDS, $data);21     }22     curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);23     $output = curl_exec($curl);24     curl_close($curl);25     return $output;26 }
三、通过ticket换取二维码

获取二维码ticket后,开发者可用ticket换取二维码图片。无须登录态即可调用。

HTTPS GET请求说明(TICKET必需UrlEncode)

https://mp.weixin.qq.com/cgi-bin/showqrcode?ticket=TICKET

ticket正确情况下,http 返回码是200,是一张图片,可以直接展示或者下载。

HTTP头示例如下:

 1 { 2     "url": "https://mp.weixin.qq.com/cgi-bin/showqrcode?ticket=gQHi8DoAAAAAAAAAASxodHRwOi8vd2VpeGluLnFxLmNvbS9xL0UweTNxNi1sdlA3RklyRnNKbUFvAAIELdnUUgMEAAAAAA%3D%3D", 3     "content_type": "image/jpg", 4     "http_code": 200, 5     "header_size": 162, 6     "request_size": 181, 7     "filetime": -1, 8     "ssl_verify_result": 20, 9     "redirect_count": 0,10     "total_time": 0.509,11     "namelookup_time": 0,12     "connect_time": 0.058,13     "pretransfer_time": 0.343,14     "size_upload": 0,15     "size_download": 28497,16     "speed_download": 55986,17     "speed_upload": 0,18     "download_content_length": 28497,19     "upload_content_length": 0,20     "starttransfer_time": 0.481,21     "redirect_time": 022 }

下面是二种场景二维码的URL及生成的图片

https://mp.weixin.qq.com/cgi-bin/showqrcode?ticket=gQFK8DoAAAAAAAAAASxodHRwOi8vd2VpeGluLnFxLmNvbS9xL3kweXE0T3JscWY3UTltc3ZPMklvAAIEG9jUUgMECAcAAA%3d%3d

https://mp.weixin.qq.com/cgi-bin/showqrcode?ticket=gQHi8DoAAAAAAAAAASxodHRwOi8vd2VpeGluLnFxLmNvbS9xL0UweTNxNi1sdlA3RklyRnNKbUFvAAIELdnUUgMEAAAAAA%3d%3d

\

四、下载二维码

二维码生成以后,可以在浏览器中右键另存为本地图片,但如果有很多二维码的时候,用程序来下载就比较方便。

我们使用CURL获取图片的所有信息,并将图片数据保存为一个文件。一个完整的下载代码如下:

$ticket = "gQHi8DoAAAAAAAAAASxodHRwOi8vd2VpeGluLnFxLmNvbS9xL0UweTNxNi1sdlA3RklyRnNKbUFvAAIELdnUUgMEAAAAAA=="; $url = "https://mp.weixin.qq.com/cgi-bin/showqrcode?ticket=".urlencode($ticket);$imageInfo = downloadImageFromWeiXin($url); $filename = "qrcode.jpg";$local_file = fopen($filename, 'w');if (false !== $local_file){    if (false !== fwrite($local_file, $imageInfo["body"])) {        fclose($local_file);    }} function downloadImageFromWeiXin($url){    $ch = curl_init($url);    curl_setopt($ch, CURLOPT_HEADER, 0);        curl_setopt($ch, CURLOPT_NOBODY, 0);    //只取body头    curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE);    curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE);    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);    $package = curl_exec($ch);    $httpinfo = curl_getinfo($ch);    curl_close($ch);    return array_merge(array('body' => $package), array('header' => $httpinfo)); }

这样,在程序当前目录就会生成一个包含二维码的图片文件。

五、扫描带参数二维码事件

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

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

如果用户已经关注公众号,则微信会将带场景值扫描事件推送给开发者。

1. 用户未关注时,进行关注后的事件推送

<xml><ToUserName><![CDATA[gh_45072270791c]]></ToUserName><FromUserName><![CDATA[o7Lp5t6n59DeX3U0C7Kric9qEx-Q]]></FromUserName><CreateTime>1389684286</CreateTime><MsgType><![CDATA[event]]></MsgType><Event><![CDATA[subscribe]]></Event><EventKey><![CDATA[qrscene_1000]]></EventKey><Ticket><![CDATA[gQHi8DoAAAAAAAAAASxodHRwOi8vd2VpeGluLnFxLmNvbS9xL0UweTNxNi1sdlA3RklyRnNKbUFvAAIELdnUUgMEAAAAAA==]]></Ticket></xml>

参数说明

\

2. 用户已关注时的事件推送

<xml><ToUserName><![CDATA[gh_45072270791c]]></ToUserName><FromUserName><![CDATA[o7Lp5t6n59DeX3U0C7Kric9qEx-Q]]></FromUserName><CreateTime>1389684184</CreateTime><MsgType><![CDATA[event]]></MsgType><Event><![CDATA[SCAN]]></Event><EventKey><![CDATA[1000]]></EventKey><Ticket><![CDATA[gQHi8DoAAAAAAAAAASxodHRwOi8vd2VpeGluLnFxLmNvbS9xL0UweTNxNi1sdlA3RklyRnNKbUFvAAIELdnUUgMEAAAAAA==]]></Ticket></xml>

参数说明

\

事件代码:

以下代码判定了扫描带参数二维码的两种情形

private function receiveEvent($object){    $contentStr = "";    switch ($object->Event)    {        case "subscribe":            $contentStr = "欢迎关注 ";            if (isset($object->EventKey)){                $contentStr = "关注二维码场景 ".$object->EventKey;            }            break;        case "SCAN":            $contentStr = "扫描 ".$object->EventKey;            break;        default:            break;           }    $resultStr = $this->transmitText($object, $contentStr);    return $resultStr;}
0 0
原创粉丝点击