찾다
php教程PHP源码[原创]微信公众平台之快递查询功能

微信公众平台的快递查询功能的开发,原汁原味的原创。By:Skiychan www.zzzzy.com
使用方法:
#查快递(或三个首字母ckd)#快递编号#快递单号
如(查询EMS单号为1034616494006的快递):
#ckd#15#1034616494006

常用快递编号:df250b2156c434f3390392d09b1c9563
15EMS,56申通,57顺丰,77圆通,
80韵达,87中通,85宅急送,62天天

<?php
/**
 *  微信公众平台基础类 For Fshare
 *  @author:    Skiychan
 *  @created:   2013.11.19
 */
 
class Wechat{
//  public $token = &#39;&#39;;
     
/*  public function __construct($token){
        $this->token = $token;
    }   */
     
    //判断是否来自微信服务器
/*  public function valid(){
        $echoStr = $_GET["echostr"];
 
        if($this->checkSignature()){
            echo $echoStr;
            exit;
        }
    }
*/
     
    public function responseMsg(){
            
        $postStr = $GLOBALS["HTTP_RAW_POST_DATA"];
             
        if (!empty($postStr)){
             
            $postObj = simplexml_load_string($postStr, &#39;SimpleXMLElement&#39;, LIBXML_NOCDATA);
            $fromUsername = $postObj->FromUserName;
            $toUsername = $postObj->ToUserName;
            $keyword = trim($postObj->Content);
            $time = time();
            $textTpl = "<xml>
                        <ToUserName><![CDATA[%s]]></ToUserName>
                        <FromUserName><![CDATA[%s]]></FromUserName>
                        <CreateTime>%s</CreateTime>
                        <MsgType><![CDATA[%s]]></MsgType>
                        <Content><![CDATA[%s]]></Content>
                        <FuncFlag>0</FuncFlag>
                        </xml>";              
            if(!empty($keyword)){
                 
                //当输入文字类型
                if($msgType = "text"){
                    //$contentStr = $keyword.$fromUsername.$time;
                    //$preg = "/^\#([\W\w]*?)\#([\W\w]*?)\#(.*)/";  //0为功能,1为选项,2为余下的值
                    //$preg = "/\#([\w]+)/";    //0为功能,1为选项,2为余下的值
                    $preg = "/\#([\w\d\x{4e00}-\x{9fa5}]+)/u";  //0为功能,1为选项,2为余下的值
                    preg_match_all($preg,$keyword,$newdata);
                    $fn_name = $newdata[1][0];
                     
                    //获取快递的参数
                    if(strtolower($fn_name)=="skiy"){
                        $me = "我是此公众帐号的开发者,英文名Skiy。\n如果你对本功能有任何意见和建议,欢迎联系我,\n我的QQ是1005043848\n微信是forskiy,邮箱:\ndeveloper@zzzzy.com\n网站:www.zzzzy.com";
                        $contentStr = $me;
                    }                   
                         
                    //获取快递的参数
                    if($fn_name=="快递"||strtolower($fn_name)=="kuaidi"){
                         
                        $kdlist = &#39;&#39;;
                        //启用PDO连接sqlite的方式
                        $db = new PDO("sqlite:somedata/data.dat");
                        $results = $db->query(&#39;SELECT * FROM kuaidi&#39;)->fetchAll();
                        foreach ($results as $key=>$row) {
                            //var_dump($row);
                            //$list_one = $row[&#39;id&#39;]." ".$row[&#39;code&#39;]." ".$row[&#39;company&#39;]."\n";
                            $list_one = $row[&#39;id&#39;].&#39; &#39;.$row[&#39;company&#39;]."\n";
                            $kdlist = $kdlist.$list_one;
                        }   
                         
                        //主机支持sqlite3的方式
/*                      $db = new SQLite3("somedata/data.dat");
                        $results = $db->query(&#39;SELECT * FROM kuaidi&#39;);
                        while ($row = $results->fetchArray()) {
                            //var_dump($row);
                            $list_one = $row[&#39;id&#39;]." ".$row[&#39;code&#39;]." ".$row[&#39;company&#39;]."\n\r";
                            $kdlist = $kdlist.$list_one;
                        }   */     
                         
                        $contentStr = $kdlist;
                    }
                                         
                         
                    if($fn_name=="查快递"||strtolower($fn_name)=="ckd"){
                        $id = $newdata[1][1];
                        $num = $newdata[1][2];
                         
                        $db = new PDO("sqlite:somedata/data.dat");
                        $results = $db->query(&#39;SELECT code,company FROM kuaidi WHERE id = &#39;.$id)->fetchAll();
                         
                        $code = $results[0][&#39;code&#39;];        //获取英文代码
                        $com =  $results[0][&#39;company&#39;];     //获取公司名称
                         
                        $numinfo = "快递:".$com."\n"."单号:".$num."\n";
                        $kd_url = "http://m.kuaidi100.com/query?type=".$code."&postid=".$num;
                        $json_getdata = file_get_contents($kd_url);
                        $get_kdinfo = json_decode($json_getdata);   //object
                        $get_kdinfo = json_decode($json_getdata,true);  //array
 
                        $last_t = "查询时间:\n".$get_kdinfo[&#39;updatetime&#39;]."\n\n";   //查询时间
                             
                        $kd_shipinfo =  $get_kdinfo[&#39;data&#39;];    //快递数据数组
                        $kd_total = count($kd_shipinfo)-1;
                        $ship = &#39;&#39;;
                         
                        //物流倒序详情
                        for($i = $kd_total;$i>=0;$i--){
                            $shipinfo = $kd_shipinfo[$i][&#39;time&#39;]."\n".$kd_shipinfo[$i][&#39;context&#39;]."\n";
                            $ship = $shipinfo.$ship;
                        }
                        //顺序物流详情
                        /*foreach ($kd_shipinfo as $v){
                            $shipinfo = $v[&#39;time&#39;]."\n".$v[&#39;context&#39;]."\n";
                            $ship = $shipinfo.$ship;
                        }
                        */
                        $get_kdinfo = $numinfo.$last_t."【物流详情】\n".$ship;
                        if($ship){
                            $contentStr = $get_kdinfo;
                        }else{
                            $contentStr = $numinfo.">没有物流数据!";
                        }
                    }
 
                    $resultStr = sprintf($textTpl, $fromUsername, $toUsername, $time, $msgType, $contentStr);
                    echo $resultStr;
                }else{
                    echo "Input something...";
                }
            }
        }else {
            echo "You have no enter something...";
            exit;
        }
    }
     
     
    //判断签名,返回bool
    private function checkSignature(){
        $signature = $_GET["signature"];
        $timestamp = $_GET["timestamp"];
        $nonce = $_GET["nonce"];    
                 
        $token = TOKEN;
        $tmpArr = array($token, $timestamp, $nonce);
        sort($tmpArr);
        $tmpStr = implode( $tmpArr );
        $tmpStr = sha1( $tmpStr );
         
        if( $tmpStr == $signature ){
            return true;
        }else{
            return false;
        }
    }
}

2.index.php

<?php
/**
 * 
 * 微信公众平台消息接口 For Fshare(分享资讯)
 * @author: Skiychan    (Wechat:forskiy)
 * @created:2013.11.19
 * 
 */
 
include_once &#39;class.base.php&#39;;
 
define(&#39;TOKEN&#39;, &#39;skiychan&#39;);
 
$wx = new Wechat();
 
//$wx->valid();
$wx->responseMsg();
성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

SublimeText3 Linux 새 버전

SublimeText3 Linux 새 버전

SublimeText3 Linux 최신 버전

VSCode Windows 64비트 다운로드

VSCode Windows 64비트 다운로드

Microsoft에서 출시한 강력한 무료 IDE 편집기

MinGW - Windows용 미니멀리스트 GNU

MinGW - Windows용 미니멀리스트 GNU

이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

Dreamweaver Mac版

Dreamweaver Mac版

시각적 웹 개발 도구

DVWA

DVWA

DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는