使用“扫码推事件”菜单,可以获得扫码结果,再通过第三方快递查询接口,可以实现扫描快递条码查询快递进度的功能。
微信类中创建菜单的函数如下。
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 快递查询效果图