이 글의 예시에서는 SAE 실시간 로그 인터페이스 SDK의 사용법을 설명합니다. 참고하실 수 있도록 자세한 내용은 다음과 같습니다.
Sina SAE는 Sina R&D Center에서 개발한 국내 최초의 퍼블릭 클라우드 플랫폼으로 2009년 이후 점점 더 성숙해졌으며 많은 인터페이스를 오픈했습니다. 및 서비스 제공업체가 사용합니다. 이번에는 개발자의 디버깅 및 분석을 용이하게 하기 위해 SAE가 새로운 실시간 로그 쿼리 인터페이스를 추가했습니다. 앞으로는 API를 통해 로그 정보를 필터링하고 필요한 실시간 로그를 다운로드할 수 있습니다. 그러나 Sina SAE는 공식적으로 Python 구현만 제공합니다. 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]['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 时间 * @param string 日志类型 * @param string 过滤符 * @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请求头 * @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; } }
를 호출하는 인터페이스의 PHP 버전은 SaeApiHandler 클래스를 인스턴스화하고 getLog()를 호출하기만 하면 됩니다. 방법. 이 방법은 배열 매개변수 또는 문자열을 전달할 수 있습니다. 자세한 내용은 SAE 설명서를 참조하세요. 여러 로그 세트를 반환해야 하는 경우 여러 배열을 전달하면 됩니다.
$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);
이 글이 PHP 프로그래밍에 종사하는 모든 분들께 도움이 되기를 바랍니다.
더 많은 SAE 실시간 로그 인터페이스 SDK 사용 예시 및 관련 기사를 보려면 PHP 중국어 웹사이트를 주목하세요!