SAE实时日志接口SDK用法示例


Posted in PHP onOctober 09, 2016

本文实例讲述了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]['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;
  }
}

使用也很简单,实例化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程序设计有所帮助。

PHP 相关文章推荐
做个自己站内搜索引擎
Oct 09 PHP
PHP截取汉字乱码问题解决方法mb_substr函数的应用
Mar 30 PHP
php初学者写及时补给skype用户充话费的小程序
Nov 02 PHP
php下安装配置fckeditor编辑器的方法
Mar 02 PHP
php继承的一个应用
Sep 06 PHP
初识通用数据库操作类――前端easyui-datagrid,form(php)
Jul 31 PHP
使用PHP接受文件并获得其后缀名的方法
Aug 05 PHP
php文件扩展名判断及获取文件扩展名的N种方法
Sep 12 PHP
PHP执行SQL文件并将SQL文件导入到数据库
Sep 17 PHP
php生成验证码,缩略图及水印图的类分享
Apr 07 PHP
php中的钩子理解及应用实例分析
Aug 30 PHP
layui数据表格自定义每页条数limit设置
Oct 26 PHP
对PHP依赖注入的理解实例分析
Oct 09 #PHP
mac下多个php版本快速切换的方法
Oct 09 #PHP
Laravel中间件实现原理详解
Oct 09 #PHP
Laravel 5.1 on SAE环境开发教程【附项目demo源码】
Oct 09 #PHP
ThinkPHP的SAE开发相关注意事项详解
Oct 09 #PHP
Laravel的throttle中间件失效问题解决方法
Oct 09 #PHP
Laravel日志用法详解
Oct 09 #PHP
You might like
php学习 函数 课件
2008/06/15 PHP
PHP访问MYSQL数据库封装类(附函数说明)
2010/12/04 PHP
MySQL 日期时间函数常用总结
2012/06/12 PHP
php利用scws实现mysql全文搜索功能的方法
2014/12/25 PHP
PHP 配置后台登录以及模板引入
2017/01/24 PHP
php实现通过soap调用.Net的WebService asmx文件
2017/02/27 PHP
解决php-fpm.service not found问题的办法
2017/06/06 PHP
PHP过滤器 filter_has_var() 函数用法实例分析
2020/04/23 PHP
JavaScript获取页面上某个元素的代码
2011/03/13 Javascript
jQuery.clean使用方法及思路分析
2013/01/07 Javascript
jQuery基本选择器选择元素使用介绍
2013/04/18 Javascript
javascript中onclick(this)用法介绍
2013/04/19 Javascript
JScript中的条件注释详解
2015/04/24 Javascript
JavaScript和JQuery的鼠标mouse事件冒泡处理
2015/06/19 Javascript
JavaScript实现自动弹出窗口并自动关闭窗口的方法
2015/08/06 Javascript
jQuery表单验证功能实例
2015/08/28 Javascript
javascript数组遍历的方法实例分析
2016/09/13 Javascript
详解Vue生命周期的示例
2017/03/10 Javascript
node实现简单的反向代理服务器
2017/07/26 Javascript
Vue实现滑动拼图验证码功能
2019/09/15 Javascript
vue实现将一个数组内的相同数据进行合并
2019/11/07 Javascript
vue项目中定义全局变量、函数的几种方法
2019/11/08 Javascript
[02:06]2018完美世界全国高校联赛秋季赛开始报名(附彩蛋)
2018/09/03 DOTA
Python在groupby分组后提取指定位置记录方法
2018/04/20 Python
Python 实现将数组/矩阵转换成Image类
2020/01/09 Python
Python如何使用OS模块调用cmd
2020/02/27 Python
无需压缩软件,用python帮你操作压缩包
2020/08/17 Python
检测用户浏览器是否支持CSS3的方法
2009/08/29 HTML / CSS
艺术专业大学生自我评价
2013/09/22 职场文书
实习教师自我鉴定
2013/09/27 职场文书
教育系毕业生中文求职信范文
2013/10/06 职场文书
2015年医务科工作总结范文
2015/05/26 职场文书
公安纪律作风整顿心得体会
2016/01/23 职场文书
python非标准时间的转换
2021/07/25 Python
ORACLE中dbms_output.put_line输出问题的解决过程
2022/06/28 Oracle
Python+pyaudio实现音频控制示例详解
2022/07/23 Python