PHP realizes third-party instant access to logistics updates

墨辰丷
Release: 2023-03-27 16:56:01
Original
1799 people have browsed it

This article mainly introduces PHP to realize third-party real-time acquisition of logistics updates. It is very good and has reference value. Friends in need can refer to it

Preface

There is a requirement for a recent project, which is to use the logistics order number to instantly query logistics information. I learned from the Internet that there are still many third-party APIs about logistics, and the one I chose is Express Bird, Express Bird It is a free third-party interface. The API integrates more than 400 logistics and express delivery interfaces around the world. It is permanently free and unlimited. The interface communicates with the express delivery company through multiple channels. The availability reaches more than 99.9%. The push speed is customized and configured to ensure the stability of the access party's system. .

Usage process

Log in to the website http://www.kdniao.com/ and you must first register. After registration, go to the user management background , there is an option to apply for API. Note that real-name authentication is required before applying for API. After authentication, you can apply for API. Its API interface is still very rich.

PHP realizes third-party instant access to logistics updates

Because if I use real-time query, I apply for the real-time query API.

API usage flow chart

PHP realizes third-party instant access to logistics updates

As can be seen from the flow chart

The user only needs to provide the express delivery number and express delivery The company

gets the logistics status through the API and returns the result to

. We get the result and process it in real time for display.

API parameters

PHP realizes third-party instant access to logistics updates

PHP realizes third-party instant access to logistics updates

The above are official About the API parameters, we can look at the official demo to learn more. The official demo is also simple and easy to understand. We can encapsulate it again.

Encapsulated API

Using the API requires three fixed parameters

1. Merchant ID

2. API key

3. Request URL, ReqURL

The merchant ID and API key can be seen on the My Management homepage of the Express Bird website, and the request URL is

http://api. kdniao.cc/Ebusiness/EbusinessOrderHandle.aspx, this can be seen in the interface document.

Main method

/**
 * @param $ShipperCode 快递公司编号
 * @param $order_sn 运单号
 */
public function getMessage($ShipperCode,$order_sn){
  $requestData= "{'OrderCode':'','ShipperCode':'".$ShipperCode."','LogisticCode':'".$order_sn."'}";
  $datas = array(
    'EBusinessID' => self::EBusinessID,
    'RequestType' => '1002',//接口指令1002,固定
    'RequestData' => urlencode($requestData) ,
    'DataType' => '2', //数据返回格式 2 json
  );
  //把$requestData进行加密处理
  $datas['DataSign'] = $this -> encrypt($requestData, self::AppKey);
  $result = $this -> sendPost( self::ReqURL, $datas);
  return $result;
}
Copy after login

In this main method, there are two parameters passed in, one is the express company number, and the other is the logistics order Number.

PHP realizes third-party instant access to logistics updates

We also need to encrypt $requestData, which is the encrypt method.

/*
 * 进行加密
 */
function encrypt($data, $appkey) {
  return urlencode(base64_encode(md5($data.$appkey)));
}
Copy after login

After encryption, access directly through ReqURL, and the returned data is logistics information.

PHP realizes third-party instant access to logistics updates

Source code

<?php
/**
 * 使用快递鸟api进行查询
 * User: Administrator
 * Date: 2017/4/22 0022
 * Time: 09:09
 */
class KuaidiController{
  const EBusinessID = 1285564;
  const AppKey = &#39;264ff9e0-2f4c-48d5-877f-1e0670400d18&#39;;
  const ReqURL = "http://api.kdniao.cc/Ebusiness/EbusinessOrderHandle.aspx";
  /**
   * @param $ShipperCode 快递公司编号
   * @param $order_sn 运单号
   */
  public function getMessage($ShipperCode,$order_sn){
    $requestData= "{&#39;OrderCode&#39;:&#39;&#39;,&#39;ShipperCode&#39;:&#39;".$ShipperCode."&#39;,&#39;LogisticCode&#39;:&#39;".$order_sn."&#39;}";
    $datas = array(
      &#39;EBusinessID&#39; => self::EBusinessID,
      &#39;RequestType&#39; => &#39;1002&#39;,//接口指令1002,固定
      &#39;RequestData&#39; => urlencode($requestData) ,
      &#39;DataType&#39; => &#39;2&#39;, //数据返回格式 2 json
    );
    //把$requestData进行加密处理
    $datas[&#39;DataSign&#39;] = $this -> encrypt($requestData, self::AppKey);
    $result = $this -> sendPost( self::ReqURL, $datas);
    return $result;
  }
  /**
   * post提交数据
   * @param string $url 请求Url
   * @param array $datas 提交的数据
   * @return url响应返回的html
   */
  function sendPost($url, $datas) {
    $temps = array();
    foreach ($datas as $key => $value) {
      $temps[] = sprintf(&#39;%s=%s&#39;, $key, $value);
    }
    $post_data = implode(&#39;&&#39;, $temps);
    $url_info = parse_url($url);
    if(empty($url_info[&#39;port&#39;]))
    {
      $url_info[&#39;port&#39;]=80;
    }
    $httpheader = "POST " . $url_info[&#39;path&#39;] . " HTTP/1.0\r\n";
    $httpheader.= "Host:" . $url_info[&#39;host&#39;] . "\r\n";
    $httpheader.= "Content-Type:application/x-www-form-urlencoded\r\n";
    $httpheader.= "Content-Length:" . strlen($post_data) . "\r\n";
    $httpheader.= "Connection:close\r\n\r\n";
    $httpheader.= $post_data;
    $fd = fsockopen($url_info[&#39;host&#39;], $url_info[&#39;port&#39;]);
    fwrite($fd, $httpheader);
    $gets = "";
    $headerFlag = true;
    while (!feof($fd)) {
      if (($header = @fgets($fd)) && ($header == "\r\n" || $header == "\n")) {
        break;
      }
    }
    while (!feof($fd)) {
      $gets.= fread($fd, 128);
    }
    fclose($fd);
    return $gets;
  }
  /*
   * 进行加密
   */
  function encrypt($data, $appkey) {
    return urlencode(base64_encode(md5($data.$appkey)));
  }
}
$model = new KuaidiController();
$res = $model -> getMessage(&#39;ZTO&#39;,&#39;12345678&#39;);
echo "<pre class="brush:php;toolbar:false">";
var_dump($res);
Copy after login

The above is the entire content of this article, I hope it will be useful for everyone’s learning help.


Related recommendations:

php removes all spaces in the string

Send two small things, ASP/PHP learning tools. Written in JavaScript_javascript skills

php book xml format data example based on dom_php skills

The above is the detailed content of PHP realizes third-party instant access to logistics updates. For more information, please follow other related articles on the PHP Chinese website!

Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template