豆瓣的账号登录及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=$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,
            ‘state‘=>md5(time())
        );
        return ‘https://www.douban.com/service/auth2/auth?‘.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://www.douban.com/service/auth2/token‘;
        return $this->http($url, http_build_query($params), ‘POST‘);
    }

    function access_token_refresh($callback_url, $refresh_token){
        $params=array(
            ‘grant_type‘=>‘refresh_token‘,
            ‘refresh_token‘=>$refresh_token,
            ‘client_id‘=>$this->client_id,
            ‘client_secret‘=>$this->client_secret,
            ‘redirect_uri‘=>$callback_url
        );
        $url=‘https://www.douban.com/service/auth2/token‘;
        return $this->http($url, http_build_query($params), ‘POST‘);
    }

    function me(){
        $params=array();
        $url=‘https://api.douban.com/v2/user/~me‘;
        return $this->api($url, $params);
    }

    function share($text, $title, $url, $description=‘‘, $pic=‘‘){
        $params=array(
            ‘text‘=>$text,
            ‘rec_title‘=>$title,
            ‘rec_url‘=>$url,
            ‘rec_desc‘=>$description,
            ‘rec_image‘=>$pic
        );
        $url=‘https://api.douban.com/shuo/v2/statuses/‘;
        return $this->api($url, $params, ‘POST‘);
    }

    function api($url, $params, $method=‘GET‘){
        $headers[]="Authorization: Bearer ".$this->access_token;
        if($method==‘GET‘){
            $result=$this->http($url.‘?‘.http_build_query($params), ‘‘, ‘GET‘, $headers);
        }else{
            $result=$this->http($url, http_build_query($params), ‘POST‘, $headers);
        }
        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: doubanPHP(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‘);

$douban_k=‘‘; //豆瓣应用API Key
$douban_s=‘‘; //豆瓣应用Secret
$callback_url=‘http://yoururl/callback.php‘; //授权回调网址
$scope=‘douban_basic_common,shuo_basic_w‘; //权限列表,具体权限请查看官方的api文档
?>  
3.index.php 
<?php
session_start();
require_once(‘config.php‘);
require_once(‘douban.php‘);

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

//检查是否已登录
if($douban_t!=‘‘){
    $douban=new doubanPHP($douban_k, $douban_s, $douban_t);

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

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

    /**
    //发布分享
    $text=‘分享内容‘;
    $title=‘分享标题‘;
    $url=‘http://www.oschina.net/‘;
    $result=$douban->share($text, $title, $url);
    var_dump($result);
    **/

}else{
    //生成登录链接
    $douban=new doubanPHP($douban_k, $douban_s);
    $login_url=$douban->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(‘douban.php‘);

if(isset($_GET[‘code‘]) && $_GET[‘code‘]!=‘‘){
    $douban=new doubanPHP($douban_k, $douban_s);
    $result=$douban->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[‘douban_t‘]=$result[‘access_token‘]; //access token
    $_SESSION[‘douban_r‘]=$result[‘refresh_token‘]; //refresh token
}else{
    echo ‘授权失败‘;
}
echo ‘<br/><a href="./">返回</a>‘;
?>
时间: 2024-07-29 04:48:25

豆瓣的账号登录及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.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=$c

[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目前