首頁  >  文章  >  php教程  >  SAE即時日誌介面SDK用法範例

SAE即時日誌介面SDK用法範例

高洛峰
高洛峰原創
2016-12-20 16:08:511096瀏覽

本文實例講述了SAE即時日誌介面SDK用法。分享給大家供大家參考,具體如下:

新浪SAE是新浪研發中心開發的國內首個公有雲平台,從2009年開始到現在也是也來越成熟,開放了很多接口以及服務供開發者使用。這次為了方便開發者調試分析,SAE新增即時日誌查詢介面。今後您可以透過API對日誌資訊進行篩選,並下載所需的即時日誌。但是新浪SAE官方只給的Python的實現,這裡給出PHP版本的介面呼叫SDK

class SaeApiHandler{
  /**
  *  定义accessKey
  */
  private $accessKey;
  /**
  *  定义secretKey
  */
  private $secretKey;
  /**
  *  定义时间戳
  */
  private $timestamp;
  /**
  *  构造函数
  */
  public function __construct($key,$sec){
    $this->accessKey = $key;
    $this->secretKey = $sec;
    $this->timestamp = time();
  }
  /**
  *  重载get方法
  */
  public function __call($name,$arg){
    $ret = array();
    if (is_array($arg[0])) {
      $len = count($arg);
      for ($i=0; $i < $len; $i++) {
        $ret[$i] = $arg[$i][&#39;fop&#39;] ? $this->$name($arg[$i][&#39;service&#39;],$arg[$i][&#39;date&#39;],$arg[$i][&#39;ident&#39;],$arg[$i][&#39;fop&#39;]):$this->$name($arg[$i][&#39;service&#39;],$arg[$i][&#39;date&#39;],$arg[$i][&#39;ident&#39;]);
      }
    }else{
      $ret = $arg[3] ? $this->$name($arg[0],$arg[1],$arg[2],$arg[3]) : $this->get($arg[0],$arg[1],$arg[2]);
    }
    return $ret;
  }
  /**
  *  获取日志
  *  @param string 需要的日志
  *  @param string 时间
  *  @param string 日志类型
  *  @param string 过滤符
  *  @return array
  */
  private function getLog($service,$date,$ident,$fop=null){
    if ($fop) {
      $uri = &#39;/log/&#39;.$service.&#39;/&#39;.$date.&#39;/&#39;.$_SERVER[&#39;HTTP_APPVERSION&#39;].&#39;-&#39;.$ident.&#39;.log?&#39;.$fop;
    }else{
      $uri = &#39;/log/&#39;.$service.&#39;/&#39;.$date.&#39;/&#39;.$_SERVER[&#39;HTTP_APPVERSION&#39;].&#39;-&#39;.$ident.&#39;.log&#39;;
    }
    $ret = explode(PHP_EOL,$this->get($uri));
    array_splice($ret,0,7);
    array_pop($ret);
    return $ret;
  }
  private function get($uri){
    $host = &#39;http://g.sae.sina.com.cn&#39;.$uri;
    $ch = curl_init();
    curl_setopt($ch, CURLOPT_URL,$host);
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
    curl_setopt($ch, CURLOPT_HTTPHEADER, $this->saeHeader($uri));
    curl_setopt($ch, CURLOPT_HEADER, 1);
    $ret = curl_exec($ch);
    curl_close($ch);
    return $ret;
  }
  /**
  *  SAE请求头
  *  @return array
  */
  private function saeHeader($uri){
    return array(
        &#39;Host: g.sae.sina.com.cn&#39;,
        &#39;Accept: text/plain&#39;,
        &#39;x-sae-accesskey: &#39;.$this->accessKey,
        &#39;x-sae-timestamp: &#39;.$this->timestamp,
        &#39;Authorization: &#39;. $this->getAuthorization($uri)
      );
  }
  /**
  *  获取gAuthorization
  */
  private function getAuthorization($uri){
    $header = array(
        &#39;x-sae-timestamp&#39; => $this->timestamp,
        &#39;x-sae-accesskey&#39; => strtolower($this->accessKey)
      );
    ksort($header);
    $sae_header = array(&#39;GET&#39;,$uri);
    foreach ($header as $key => $value) {
      $sae_header[count($sae_header)] = $key.&#39;:&#39;.$value;
    }
    $ret = implode(PHP_EOL, $sae_header);
    $auth = &#39;SAEV1_HMAC_SHA256 &#39;.base64_encode(hash_hmac(&#39;sha256&#39;,$ret,$this->secretKey,true));
    return $auth;
  }
}

使用也很簡單,實例化SaeApiHandler類,呼叫getLog()方法即可。此方法可以傳遞陣列參數或字串,具體可以到SAE文件看,如果需要傳回多組日誌,則傳遞多個陣列即可。

$test = new SaeApiHandler(SAE_ACCESSKEY,SAE_SECRETKEY);
$arr1 = array(
  &#39;service&#39;=>&#39;http&#39;,
  &#39;date&#39;=>&#39;2015-07-03&#39;,
  &#39;ident&#39;=>&#39;access&#39;,
  &#39;fop&#39;=>&#39;head/1/5&#39;
  );
$arr2 = array(
  &#39;service&#39;=>&#39;http&#39;,
  &#39;date&#39;=>&#39;2015-07-03&#39;,
  &#39;ident&#39;=>&#39;access&#39;,
  &#39;fop&#39;=>&#39;head/1/5&#39;
  );
$ret = $test->getLog($arr1,$arr2);
var_dump($ret);

希望本文所述對大家PHP程式設計有所幫助。

更多SAE即時日誌介面SDK用法範例相關文章請關注PHP中文網!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn