使用“扫码推事件”菜单,可以获得扫码结果,再通过第三方快递查询接口,可以实现扫描快递条码查询快递进度的功能。
微信类中创建菜单的函数如下。
1 // 创建菜单
2 public function create_menu($button, $matchrule = NULL)
3 {
4 foreach ($button as &$item) {
5 foreach ($item as $k => $v) {
6 if (is_array($v)){
7 foreach ($item[$k] as &$subitem) {
8 foreach ($subitem as $k2 => $v2) {
9 $subitem[$k2] = urlencode($v2);
10 }
11 }
12 }else{
13 $item[$k] = urlencode($v);
14 }
15 }
16 }
17
18 if (isset($matchrule) && !is_null($matchrule)){
19 foreach ($matchrule as $k => $v) {
20 $matchrule[$k] = urlencode($v);
21 }
22 $data = urldecode(json_encode(array('button' => $button, 'matchrule' =>
$matchrule)));
23 $url = "https:// api.weixin.qq.com/cgi-bin/menu/addconditional?access_token=".
$this->access_token;
24 }else{
25 $data = urldecode(json_encode(array('button' => $button)));
26 $url = "https:// api.weixin.qq.com/cgi-bin/menu/create?access_token=".$th
is->access_token;
27 }
28 $res = $this->http_request($url, $data);
29 return json_decode($res, true);
30 }
上述代码解读如下。
第4~16行:将菜单数组中的中文值进行urlencode,这是为了后面将数组转为JSON时不导致乱码。
第18行:判断是否有个性化菜单规则。
第19~23行:构建个性化菜单数据并将url接口定为个性化菜单接口。
第25~26行:构建自定义菜单数据并将url接口定为自定义菜单接口。
第28~29行:提交创建菜单请求并返回结果。
创建菜单的代码如下。
1 <?php
2 require_once('weixin.class.php');
3 $weixin = new class_weixin;
4
5 $button = array('type' => "scancode_waitmsg",
6 'name' => "扫快递码",
7 'key' => "rselfmenu_2_1"
8 );
9 $result = $weixin->create_menu($button);
10 var_dump($result);
11 ?>
执行后,底部生成菜单如图5-2所示。
图5-2 生成菜单
当点击“扫快递码”菜单时,开发者接口将收到scancode_wait-msg事件消息,该消息的处理代码如下。
1 // 接收事件消息
2 private function receiveEvent($object)
3 {
4 $content = "";
5 switch ($object->Event)
6 {
7 case "subscribe":
8 $content = "欢迎关注";
9 break;
10 case "unsubscribe":
11 $content = "取消关注";
12 break;
13 case "scancode_waitmsg":
14 if ($object->ScanCodeInfo->ScanType == "barcode"){
15 $codeinfo = explode(",",strval($object->ScanCodeInfo->ScanResult));
16 $codeValue = $codeinfo[1];
17 $content = array;
18 $content = array("Title"=>"扫描成功", "Description"=>"快递号:
".$codeValue."\r\n点击查看快递进度详情", "PicUrl"=>"", "Url" =>
"http:// m.kuaidi100.com/result.jsp?nu=".$codeValue);
19 }else{
20 $content = "不是条码";
21 }
22 break;
23 default:
24 $content = "receive a new event: ".$object->Event;
25 break;
26 }
27
28 if(is_array($content)){
29 $result = $this->transmitNews($object, $content);
30 }else{
31 $result = $this->transmitText($object, $content);
32 }
33 return $result;
34 }
上面代码中,第13行检测当前事件是否为扫描推事件,然后检测当前码是否为条形码(第14行)。如果是条形码,则将码的数值解析出来(第15~16行),再组装成一个单图文消息,消息的链接地址为“快递100”的查询接口,其中参数为解析出来的快递单号(第17~18行)。
图5-3所示是一个快递条码,当使用案例中的公众号菜单扫描该条码时,会返回一个图文消息。当用户点击该图文消息时,将自动跳转到“快递100”的页面中查询该快递的进度详情,如图5-4所示。
图5-3 快递条码
图5-4 快递查询效果图