本文實(shí)例講述了SAE實(shí)時(shí)日志接口SDK用法。分享給大家供大家參考,具體如下:
新浪SAE是新浪研發(fā)中心開(kāi)發(fā)的國(guó)內(nèi)首個(gè)公有云平臺(tái),從2009年開(kāi)始到現(xiàn)在也是也來(lái)越成熟,開(kāi)放了很多接口以及服務(wù)供開(kāi)發(fā)者使用。這次為了方便開(kāi)發(fā)者調(diào)試分析,SAE新增實(shí)時(shí)日志查詢接口。今后您可以通過(guò)API對(duì)日志信息進(jìn)行篩選,并下載所需的實(shí)時(shí)日志。但是新浪SAE官方只給出的Python的實(shí)現(xiàn),這里給出PHP版本的接口調(diào)用SDK
class SaeApiHandler{ /** * 定義accessKey */ private $accessKey; /** * 定義secretKey */ private $secretKey; /** * 定義時(shí)間戳 */ private $timestamp; /** * 構(gòu)造函數(shù) */ 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]['fop'] ? $this->$name($arg[$i]['service'],$arg[$i]['date'],$arg[$i]['ident'],$arg[$i]['fop']):$this->$name($arg[$i]['service'],$arg[$i]['date'],$arg[$i]['ident']); } }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 時(shí)間 * @param string 日志類型 * @param string 過(guò)濾符 * @return array */ private function getLog($service,$date,$ident,$fop=null){ if ($fop) { $uri = '/log/'.$service.'/'.$date.'/'.$_SERVER['HTTP_APPVERSION'].'-'.$ident.'.log?'.$fop; }else{ $uri = '/log/'.$service.'/'.$date.'/'.$_SERVER['HTTP_APPVERSION'].'-'.$ident.'.log'; } $ret = explode(PHP_EOL,$this->get($uri)); array_splice($ret,0,7); array_pop($ret); return $ret; } private function get($uri){ $host = 'http://g.sae.sina.com.cn'.$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請(qǐng)求頭 * @return array */ private function saeHeader($uri){ return array( 'Host: g.sae.sina.com.cn', 'Accept: text/plain', 'x-sae-accesskey: '.$this->accessKey, 'x-sae-timestamp: '.$this->timestamp, 'Authorization: '. $this->getAuthorization($uri) ); } /** * 獲取gAuthorization */ private function getAuthorization($uri){ $header = array( 'x-sae-timestamp' => $this->timestamp, 'x-sae-accesskey' => strtolower($this->accessKey) ); ksort($header); $sae_header = array('GET',$uri); foreach ($header as $key => $value) { $sae_header[count($sae_header)] = $key.':'.$value; } $ret = implode(PHP_EOL, $sae_header); $auth = 'SAEV1_HMAC_SHA256 '.base64_encode(hash_hmac('sha256',$ret,$this->secretKey,true)); return $auth; }}使用也很簡(jiǎn)單,實(shí)例化SaeApiHandler類,調(diào)用getLog()方法即可。該方法可以傳遞數(shù)組參數(shù)或者字符串,具體可以到SAE文檔看,如果需要返回多組日志,則傳遞多個(gè)數(shù)組即可。
$test = new SaeApiHandler(SAE_ACCESSKEY,SAE_SECRETKEY);$arr1 = array( 'service'=>'http', 'date'=>'2015-07-03', 'ident'=>'access', 'fop'=>'head/1/5' );$arr2 = array( 'service'=>'http', 'date'=>'2015-07-03', 'ident'=>'access', 'fop'=>'head/1/5' );$ret = $test->getLog($arr1,$arr2);var_dump($ret);
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
新聞熱點(diǎn)
疑難解答
圖片精選