开心网的账号登录及api操作

1.kaixin.php
<?php
/**
 * PHP Library for kaixin001.com
 *
 * @author PiscDong (http://www.piscdong.com/)
 */
class kaixinPHP
{
    function __construct($client_id, $client_secret, $access_token=NULL){
        $this->client_id=$client_id;
        $this->client_secret=$client_secret;
        $this->access_token=$access_token;
    }

    function login_url($callback_url, $scope=‘‘){
        $params=array(
            ‘response_type‘=>‘code‘,
            ‘client_id‘=>$this->client_id,
            ‘redirect_uri‘=>$callback_url,
            ‘scope‘=>$scope
        );
        return ‘http://api.kaixin001.com/oauth2/authorize?‘.http_build_query($params);
    }

    function access_token($callback_url, $code){
        $params=array(
            ‘grant_type‘=>‘authorization_code‘,
            ‘code‘=>$code,
            ‘client_id‘=>$this->client_id,
            ‘client_secret‘=>$this->client_secret,
            ‘redirect_uri‘=>$callback_url
        );
        $url=‘https://api.kaixin001.com/oauth2/access_token‘;
        return $this->http($url, http_build_query($params), ‘POST‘);
    }

    function access_token_refresh($refresh_token){
        $params=array(
            ‘grant_type‘=>‘refresh_token‘,
            ‘refresh_token‘=>$refresh_token,
            ‘client_id‘=>$this->client_id,
            ‘client_secret‘=>$this->client_secret
        );
        $url=‘https://api.kaixin001.com/oauth2/access_token‘;
        return $this->http($url, http_build_query($params), ‘POST‘);
    }

    function me(){
        $params=array();
        $url=‘https://api.kaixin001.com/users/me.json‘;
        return $this->api($url, $params);
    }

    function records_add($content, $picurl=‘‘){
        $params=array(
            ‘content‘=>$content
        );
        if($picurl!=‘‘)$params[‘picurl‘]=$picurl;
        $url=‘https://api.kaixin001.com/records/add.json‘;
        return $this->api($url, $params, ‘POST‘);
    }

    function records_me($num=10, $start=0){
        $params=array(
            ‘start‘=>$start,
            ‘num‘=>$num
        );
        $url=‘https://api.kaixin001.com/records/me.json‘;
        return $this->api($url, $params);
    }

    function comment_list($id, $uid, $num=10, $start=0){
        $params=array(
            ‘objtype‘=>‘records‘,
            ‘objid‘=>$id,
            ‘ouid‘=>$uid,
            ‘start‘=>$start,
            ‘num‘=>$num
        );
        $url=‘https://api.kaixin001.com/comment/list.json‘;
        return $this->api($url, $params);
    }

    function forward_list($id, $uid, $num=10, $start=0){
        $params=array(
            ‘objtype‘=>‘records‘,
            ‘objid‘=>$id,
            ‘ouid‘=>$uid,
            ‘start‘=>$start,
            ‘num‘=>$num
        );
        $url=‘https://api.kaixin001.com/forward/list.json‘;
        return $this->api($url, $params);
    }

    function like_show($id, $uid, $num=10, $start=0){
        $params=array(
            ‘objtype‘=>‘records‘,
            ‘objid‘=>$id,
            ‘ouid‘=>$uid,
            ‘start‘=>$start,
            ‘num‘=>$num
        );
        $url=‘https://api.kaixin001.com/like/show.json‘;
        return $this->api($url, $params);
    }

    function api($url, $params, $method=‘GET‘){
        $params[‘access_token‘]=$this->access_token;
        if($method==‘GET‘){
            $result=$this->http($url.‘?‘.http_build_query($params));
        }else{
            $result=$this->http($url, http_build_query($params), ‘POST‘);
        }
        return $result;
    }

    function http($url, $postfields=‘‘, $method=‘GET‘, $headers=array()){
        $ci=curl_init();
        curl_setopt($ci, CURLOPT_SSL_VERIFYPEER, FALSE);
        curl_setopt($ci, CURLOPT_RETURNTRANSFER, 1);
        curl_setopt($ci, CURLOPT_CONNECTTIMEOUT, 30);
        curl_setopt($ci, CURLOPT_TIMEOUT, 30);
        if($method==‘POST‘){
            curl_setopt($ci, CURLOPT_POST, TRUE);
            if($postfields!=‘‘)curl_setopt($ci, CURLOPT_POSTFIELDS, $postfields);
        }
        $headers[]="User-Agent: kaixinPHP(piscdong.com)";
        curl_setopt($ci, CURLOPT_HTTPHEADER, $headers);
        curl_setopt($ci, CURLOPT_URL, $url);
        $response=curl_exec($ci);
        curl_close($ci);
        $json_r=array();
        if($response!=‘‘)$json_r=json_decode($response, true);
        return $json_r;
    }
}

2.config.php
<?php
//配置文件
  header(‘Content-Type: text/html; charset=UTF-8‘);

  $kaixin_k=‘‘; //开心网应用API Key
  $kaixin_s=‘‘; //开心网应用Secret Key
  $callback_url=‘http://yoururl/callback.php‘; //授权回调网址
  $scope=‘create_records‘; //权限列表,具体权限请查看官方的api文档
?>
3.index.php
<?php
  session_start();
  require_once(‘config.php‘);
  require_once(‘kaixin.php‘);

  $kaixin_t=isset($_SESSION[‘kaixin_t‘])?$_SESSION[‘kaixin_t‘]:‘‘;

//检查是否已登录

  if($kaixin_t!=‘‘){
      $kaixin=new kaixinPHP($kaixin_k, $kaixin_s, $kaixin_t);

      //获取登录用户信息
      $result=$kaixin->me();
      var_dump($result);

      /**
      //access token到期后使用refresh token刷新access token
      $result=$kaixin->access_token_refresh($_SESSION[‘kaixin_r‘]);
      var_dump($result);
      **/

      /**
      //发布记录
      $img=‘http://www.baidu.com/img/baidu_sylogo1.gif‘;
      $result=$kaixin->records_add(‘记录内容‘, $img);
      var_dump($result);
      **/

  }else{
      //生成登录链接
      $kaixin=new kaixinPHP($kaixin_k, $kaixin_s);
      $login_url=$kaixin->login_url($callback_url, $scope);
      echo ‘<a href="‘,$login_url,‘">点击进入授权页面</a>‘;
  }
?>
 
 4.callback.php
<?php
//授权回调页面,即配置文件中的$callback_url
session_start();
require_once(‘config.php‘);
require_once(‘kaixin.php‘);

if(isset($_GET[‘code‘]) && $_GET[‘code‘]!=‘‘){
    $kaixin=new kaixinPHP($kaixin_k, $kaixin_s);
    $result=$kaixin->access_token($callback_url, $_GET[‘code‘]);
}
if(isset($result[‘access_token‘]) && $result[‘access_token‘]!=‘‘){
    echo ‘授权完成,请记录<br/>access token:<input size="50" value="‘,$result[‘access_token‘],‘"><br/>refresh token:<input size="50" value="‘,$result[‘refresh_token‘],‘">‘;

    //保存登录信息,此示例中使用session保存
    $_SESSION[‘kaixin_t‘]=$result[‘access_token‘]; //access token
    $_SESSION[‘kaixin_r‘]=$result[‘refresh_token‘]; //refresh token
}else{
    echo ‘授权失败‘;
}
echo ‘<br/><a href="./">返回</a>‘;
?> 
时间: 2024-07-29 04:48:30

开心网的账号登录及api操作的相关文章

新浪微博的账号登录及api操作

1.sina.php <?php /** * PHP Library for weibo.com * * @author PiscDong (http://www.piscdong.com/) */ class sinaPHP { function __construct($client_id, $client_secret, $access_token=NULL){ $this->client_id=$client_id; $this->client_secret=$client_se

豆瓣的账号登录及api操作

1.douban.php <?php /** * PHP Library for douban.com * * @author PiscDong (http://www.piscdong.com/) */ class doubanPHP { function __construct($client_id, $client_secret, $access_token=NULL){ $this->client_id=$client_id; $this->client_secret=$clie

[Android分享] 使用QQ账号,新浪微博账号登录第三方应用

转载--http://www.eoeandroid.com/thread-325071-1-1.html 最近公司由于项目要求,在应用中集成了QQ和新浪微博登录的功能,以前并没有接触过这方面的东西,前2天研究清楚,并实现了,写点心得和大家分享,同时也作为学习记录保留下来.    废话不说,直入正题了. 一.使用QQ账号登录第三方应用 这里的第三方应用指的当然是我们自己开发的应用. 腾讯开发平台是一个比较大的开放平台,它包括了腾讯微博开发平台,微信平台等诸多平台,而我们所需要用到的东西,都在QQ互

HDFS基础和java api操作

1. 概括 适合一次写入多次查询情况,不支持并发写情况 通过hadoop shell 上传的文件存放在DataNode的block中,通过linux shell只能看见block,看不见文件(HDFS将客户端的大文件存放在很多节点的数据块中,Block本质上是一个逻辑概念,它是hdfs读写数据的基本单位) HDFS中,如果一个文件小于一个数据块的大小,并不占用整个数据块存储空间 2. fs 可以使用hdfs shell操作hdfs,常用 fs命令如下: eg: hadoop fs -cat fi

关于代码通过API操作阿里云RDS的巨坑

由于项目原因,要通过API操作阿里云的数据库,于是简单研究了一下阿里云提供的相关文档,发现官方提供了.NET的SDK,而且还提供了github开源代码,这个要为阿里点赞! 于是到github上弄了一份源码,发现源码文件相当多,尝试了一下只提取几个需要用到的类文件放到项目中,经过测试好像不行,也可能本人水平未达到,反正就是不行,最终放弃. 然后测试了一下引用项目和引用dll都没有问题,基本顺利. 在测试创建用户的时候遇到了一个坑,也可以说是巨坑!在创建账号的API文档中关于AccountType的

[Ubuntu] 关于使用 root 账号登录

(本文验证环境为 Ubuntu 14.04 和 Lubuntu 13.04) Ubuntu 维护者们认为实在没有必要使用 root 帐户,因为你想做的所有事情管理员都可以完成,管理员只需使用 sudo 命令即可. 但是如果你不想每次都输入 sudo 或者坚持要使用 root 账号来做某些事情,你最好的选择是通过启动一个 shell 来模拟 root 登录,具体操作是使用如下 sudo 命令: $ sudo -i 该命令是启动一个 shell 来作为目标账号(root)的登录 shell,也就是说

浅谈第三方账号登录

最近了解了下第三方账号登录,对其中的一些心得,做了简单的整理... 现在主流的注册方式大致可分为以下两种: 1.本地账号注册 → 首页(最传统的注册方式,注册门槛高,易在登录页面就流失用户) 2.第三方注册 → (本地生成一个用户ID) → 首页(部分应用需要第二步) 要说一下的是:只要是通过第三方登录,就代表用户拿着别人给的钥匙进了自己家门,一旦这钥匙被拿走了,用户也就没了. 第1种注册方式比较传统,这里不再做过多的说明,我们来举例浅谈下第2种注册方式的优缺点: 目前不少较为稀有的资源,多是由

**15.app后端怎么设计用户登录方案(API权限安全)

在很多app中,都需要用户的登录操作.登录,就需要用到用户名和密码.为了安全起见,暴露明文密码的次数越少越好.怎么能最大程度避免泄露用户的密码呢?在登录后,app后端怎么去验证和维持用户的登录状态呢?在本文中,给出了一套用户登录的解决方案,以供大家参考. 1. 保证登录的安全性,最起码要使用https协议 避免信息的泄露,最简单的方案是所有涉及到安全性的api请求,都必须要使用https协议. HTTPS(Secure Hypertext Transfer Protocol)安全超文本传输协议

RAM SSO功能重磅发布 —— 满足客户使用企业本地账号登录阿里云

阿里云RAM (Resource Access Management)为客户提供身份与访问控制管理服务.使用RAM,可以轻松创建并管理您的用户(比如雇员.企业开发的应用程序),并控制用户对云资源的访问权限. 对云资源的信息安全保护与风险控制能力是企业成功上云的关键.RAM支持在多种云原生应用场景下,为客户提供丰富的访问控制安全机制,赋能企业在DevOps.计算环境.应用程序.数据访问等全栈系统统一实施"最小权限原则",降低云资源的***平面,有效控制企业上云的信息安全风险. RAM目前