本文作者:心月

微信公众号开发——生成二维码接口实现

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

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

目前有2种类型的二维码:

1、临时二维码,是有过期时间的,最长可以设置为在二维码生成后的30天(即2592000秒)后过期,但能够生成较多数量。临时二维码主要用于帐号绑定等不要求二维码永久保存的业务场景 
2、永久二维码,是无过期时间的,但数量较少(目前为最多10万个)。永久二维码主要用于适用于帐号绑定、用户来源统计等场景。

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

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

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


创建二维码ticket

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

临时二维码请求说明

http请求方式: POST
URL: https://api.weixin.qq.com/cgi-bin/qrcode/create?access_token=TOKEN
POST数据格式:json
POST数据例子:{"expire_seconds": 604800, "action_name": "QR_SCENE", "action_info": {"scene": {"scene_id": 123}}}

或者也可以使用以下POST数据创建字符串形式的二维码参数:
{"expire_seconds": 604800, "action_name": "QR_STR_SCENE", "action_info": {"scene": {"scene_str": "test"}}}

永久二维码请求说明

http请求方式: POST
URL: https://api.weixin.qq.com/cgi-bin/qrcode/create?access_token=TOKEN
POST数据格式:json
POST数据例子:{"action_name": "QR_LIMIT_SCENE", "action_info": {"scene": {"scene_id": 123}}}

或者也可以使用以下POST数据创建字符串形式的二维码参数:
{"action_name": "QR_LIMIT_STR_SCENE", "action_info": {"scene": {"scene_str": "test"}}}

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

        //临时二维码
	public function getQrls()
	{
		$accessToken = $this->_getWxAccessToken();
		$url = "https://api.weixin.qq.com/cgi-bin/qrcode/create?access_token={$accessToken}";
		$postArr =  [
		    "action_name" => "QR_SCENE",
		    "expire_seconds" => 604800,
		    "action_info" => [
			    'scene' => ['scene_id' => 2000],
			  ],
		 	];

		$postJson = json_encode($postArr);
		$res = $this->ch($url, 'post', 'json', $postJson);

		$ticket = $res['ticket'];
		$url = "https://mp.weixin.qq.com/cgi-bin/showqrcode?ticket=".urlencode($ticket);

		echo "<img src='".$url."'>";

	}

	//永久二维码
	public function getQryj()
	{
		$accessToken = $this->_getWxAccessToken();
		$url = "https://api.weixin.qq.com/cgi-bin/qrcode/create?access_token={$accessToken}";
		$postArr =  [
		    "action_name" => "QR_LIMIT_SCENE",
		    "action_info" => [
			    'scene' => ['scene_id' => 3000],
			  ],
		 	];

		$postJson = json_encode($postArr);
		$res = $this->ch($url, 'post', 'json', $postJson);

		$ticket = $res['ticket'];
		$url = "https://mp.weixin.qq.com/cgi-bin/showqrcode?ticket=".urlencode($ticket);

		echo "<img src='".$url."'>";
	}
	
	//url请求
	private function ch($url, $type='get', $res='json', $arr='')
	{

		$ch = curl_init();
		curl_setopt($ch, CURLOPT_URL, $url);
		curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
		curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE);
        curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE);

		if ($type == 'post') {
			curl_setopt($ch, CURLOPT_POST, 1);
			curl_setopt($ch, CURLOPT_POSTFIELDS, $arr);
		}

		$cnt = curl_exec($ch);
		if (curl_errno($ch)) {
			return;
		}

		curl_close($ch);

		if ($res == 'json') {
			return json_decode($cnt, true);
		}

		return $cnt;
	}

临时二维码生成结果:

临时二维码

永久二维码生成结果:

永久二维码

文章版权及转载声明:

作者:心月 本文地址:http://www.xinyueseo.com/other/365.html发布于 2019-10-21
文章转载或复制请以超链接形式并注明出处心月IT博客

分享到:
赞(

发表评论

快捷输入:

    评论列表 (有 0 条评论,人围观)参与讨论