.renren.php
<?php
/**
* PHP Library for renren.com
*
* @author
*/
class renrenPHP
{
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 'https://graph.renren.com/oauth/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://graph.renren.com/oauth/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://graph.renren.com/oauth/token';
return $this->http($url, http_build_query($params), 'POST');
} function me(){
$params=array();
return $this->api('users.getInfo', $params, 'POST');
} function setStatus($status){
$params=array(
'status'=>$status
);
return $this->api('status.set', $params, 'POST');
} function getStatus($uid, $count=10, $page=1){
$params=array(
'uid'=>$uid,
'page'=>$page,
'count'=>$count
);
return $this->api('status.gets', $params, 'POST');
} function addBlog($title, $content){
$params=array(
'title'=>$title,
'content'=>$content
);
return $this->api('blog.addBlog', $params, 'POST');
} function getBlog($id, $uid){
$params=array(
'id'=>$id,
'uid'=>$uid
);
return $this->api('blog.get', $params, 'POST');
} function getComments($id, $uid, $count=10, $page=1){
$params=array(
'id'=>$id,
'uid'=>$uid,
'page'=>$page,
'count'=>$count
);
return $this->api('blog.getComments', $params, 'POST');
} function api($method_name, $params, $method='GET'){
$params['method']=$method_name;
$params['v']='1.0';
$params['access_token']=$this->access_token;
$params['format']='json';
ksort($params);
$sig_str='';
foreach($params as $k=>$v)$sig_str.=$k.'='.$v;
$sig_str.=$this->client_secret;
$sig=md5($sig_str);
$params['sig']=$sig;
$url='http://api.renren.com/restserver.do';
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: renrenPHP(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;
}
}  
.config.php
<?php
//配置文件
header('Content-Type: text/html; charset=UTF-8'); $renren_k=''; //人人网应用API Key
$renren_s=''; //人人网应用Secret Key
$callback_url='http://yoururl/callback.php'; //授权回调网址
$scope='publish_blog read_user_blog'; //权限列表,具体权限请查看官方的api文档
?>  
.index.php
<?php
session_start();
require_once('config.php');
require_once('renren.php'); $renren_t=isset($_SESSION['renren_t'])?$_SESSION['renren_t']:'';
$renren_id=isset($_SESSION['renren_id'])?$_SESSION['renren_id']:''; //检查是否已登录
if($renren_t!='' || $renren_id!=''){
$renren=new renrenPHP($renren_k, $renren_s, $renren_t); //获取登录用户信息
$result=$renren->me();
var_dump($result); /**
//access token到期后使用refresh token刷新access token
$result=$renren->access_token_refresh($_SESSION['renren_r']);
var_dump($result);
**/ /**
//发布微博
$result=$renren->addBlog('微博标题', '微博内容<br/><img src="http://www.baidu.com/img/baidu_sylogo1.gif">');
var_dump($result);
**/ }else{
//生成登录链接
$renren=new renrenPHP($renren_k, $renren_s);
$login_url=$renren->login_url($callback_url, $scope);
echo '<a href="',$login_url,'">点击进入授权页面</a>';
}
?>
.callback.php
<?php
//授权回调页面,即配置文件中的$callback_url
session_start();
require_once('config.php');
require_once('renren.php'); if(isset($_GET['code']) && $_GET['code']!=''){
$renren=new renrenPHP($renren_k, $renren_s);
$result=$renren->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/>id:<input size="50" value="',$result['user']['id'],'"><br/>refresh token:<input size="50" value="',$result['refresh_token'],'">'; //保存登录信息,此示例中使用session保存
$_SESSION['renren_t']=$result['access_token']; //access token
$_SESSION['renren_id']=$result['user']['id']; //openid
$_SESSION['renren_r']=$result['refresh_token']; //refresh token
}else{
echo '授权失败';
}
echo '<br/><a href="./">返回</a>';
?> 

人人网的账号登录及api操作的更多相关文章

  1. 腾讯微博的账号登录及api操作

    .tqq.php <?php /** * PHP Library for t.qq.com * * @author */ class tqqPHP { function __construct( ...

  2. QQ的账号登录及api操作

    .qq.php <?php /** * PHP Library for qq.com * * @author */ class qqPHP { function __construct($app ...

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

    .sina.php <?php /** * PHP Library for weibo.com * * @author */ class sinaPHP { function __constru ...

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

    .kaixin.php <?php /** * PHP Library for kaixin001.com * * @author */ class kaixinPHP { function _ ...

  5. 豆瓣的账号登录及api操作

    .douban.php <?php /** * PHP Library for douban.com * * @author */ class doubanPHP { function __co ...

  6. QQ,新浪,SNS等公众平台的登录及api操作

    QQ的写法地址:http://www.oschina.net/code/snippet_930167_19888 Sina的写法地址:http://www.oschina.net/code/snipp ...

  7. git多账号登录问题

    作者:白狼 出处:http://www.manks.top/git-multiply-accounts.html 本文版权归作者,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文 ...

  8. 通过组策略实现Firefox自动以当前域账号登录MOSS站点---(原创)

    忘忧草原创,转发请保留本人的大名,谢谢,如果需要文档的请找我索取 前言 通过组策略实现基于AD的windows验证的sharepoint站点在火狐下自动以当前域账号登录. 操作步骤-在服务器添加策略工 ...

  9. SourceTree 03 - 跳过账号登录直接进入主界面

    SourceTree系列第1篇 SourceTree 01 - git 客户端介绍(http://www.cnblogs.com/geaosu/p/8807666.html) SourceTree系列 ...

随机推荐

  1. phpcms采集地址中为相对路径解决方法

    1.修改数据库v9_collection_node,增加两个字段replace_from,replace_to(varchar(200)) 2./phpcms/modules/collection/t ...

  2. visual studio 2012 插件

    下面来分享几个好用的插件:直接在Tools-Extensions and Updates-Online中搜索就可以安装了 (中文版位于:菜单-工具-扩展和更新-联机-Visual Studio库) 1 ...

  3. c#缓存 笔记

    1:缓存. 你需要了解大数据高并发的瓶颈在哪里,一般都是数据库层面的,机械硬盘承载不起非常快速的读写操作,cpu承载不起大量的逻辑运算,所以最基本的解决思路就是:1.换固态硬盘加快硬盘的读写效率.2. ...

  4. ACM/ICPC 之 最短路-SPFA+正逆邻接表(POJ1511(ZOJ2008))

    求单源最短路到其余各点,然后返回源点的总最短路长,以构造邻接表的方法不同分为两种解法. POJ1511(ZOJ2008)-Invitation Cards 改变构造邻接表的方法后,分为两种解法 解法一 ...

  5. Effective C++ -----条款39:明智而审慎地使用private继承

    Private继承意味is-implemented-in-terms of(根据某物实现出).它通常比复合(composition)的级别低.但是当derived class需要访问protected ...

  6. nyoj_148_fibonacci数列(二)_矩阵快速幂

    fibonacci数列(二) 时间限制:1000 ms  |  内存限制:65535 KB 难度:3   描述 In the Fibonacci integer sequence, F0 = 0, F ...

  7. Binary String Matching

    问题 B: Binary String Matching 时间限制: 3 Sec  内存限制: 128 MB提交: 4  解决: 2[提交][状态][讨论版] 题目描述 Given two strin ...

  8. Android仿快递 物流时间轴 的代码实现

    首先,这篇参考了别人的代码.根据自己的项目需求简单改造了一下,效果图如下 xml:代码 <?xml version="1.0" encoding="utf-8&qu ...

  9. 【leetcode】Bitwise AND of Numbers Range(middle)

    Given a range [m, n] where 0 <= m <= n <= 2147483647, return the bitwise AND of all numbers ...

  10. 移动端hrml模板

    <!DOCTYPE html><html><head> <title>时钟</title> <meta charset="u ...