ホームページ >php教程 >php手册 >RenrenアカウントのログインとPHP APIの操作

RenrenアカウントのログインとPHP APIの操作

WBOY
WBOYオリジナル
2016-06-21 08:50:011598ブラウズ

Renren のアカウント ログインと API 操作は oauth 2.0 を使用します
提供されている公式 SDK は大きすぎます。これは簡単なアカウントのログイン、個人情報の取得、Weibo の公開などの機能を提供します。その他の機能が必要な場合は、公式 API ドキュメントに従って自分で追加できます。

[ファイル] renren.php

001 <?php

002 /**

003 * PHP Library for renren.com

004 *

005 * @author PiscDong (http://www.piscdong.com/ www.php100.com)

006 */

007 class renrenPHP

008 {

009 function __construct($client_id, $client_secret, $access_token=NULL){

010 $this->client_id=$client_id;

011 $this->client_secret=$client_secret;

012 $this->access_token=$access_token;

013 }

014  

015 function login_url($callback_url, $scope=''){

016 $params=array(

017 'response_type'=>'code',

018 'client_id'=>$this->client_id,

019 'redirect_uri'=>$callback_url,

020 'scope'=>$scope

021 );

022 return 'https://graph.renren.com/oauth/authorize?'.http_build_query($params);

023 }

024  

025 function access_token($callback_url, $code){

026 $params=array(

027 'grant_type'=>'authorization_code',

028 'code'=>$code,

029 'client_id'=>$this->client_id,

030 'client_secret'=>$this->client_secret,

031 'redirect_uri'=>$callback_url

032 );

033 $url='https://graph.renren.com/oauth/token';

034 return $this->http($url, http_build_query($params), 'POST');

035 }

036  

037 function access_token_refresh($refresh_token){

038 $params=array(

039 'grant_type'=>'refresh_token',

040 'refresh_token'=>$refresh_token,

041 'client_id'=>$this->client_id,

042 'client_secret'=>$this->client_secret

043 );

044 $url='https://graph.renren.com/oauth/token';

045 return $this->http($url, http_build_query($params), 'POST');

046 }

047  

048 function me(){

049 $params=array();

050 return $this->api('users.getInfo', $params, 'POST');

051 }

052  

053 function setStatus($status){

054 $params=array(

055 'status'=>$status

056 );

057 return $this->api('status.set', $params, 'POST');

058 }

059  

060 function getStatus($uid, $count=10, $page=1){

061 $params=array(

062 'uid'=>$uid,

063 'page'=>$page,

064 'count'=>$count

065 );

066 return $this->api('status.gets', $params, 'POST');

067 }

068  

069 function addBlog($title, $content){

070 $params=array(

071 'title'=>$title,

072 'content'=>$content

073 );

074 return $this->api('blog.addBlog', $params, 'POST');

075 }

076  

077 function getBlog($id, $uid){

078 $params=array(

079 'id'=>$id,

080 'uid'=>$uid

081 );

082 return $this->api('blog.get', $params, 'POST');

083 }

084  

085 function getComments($id, $uid, $count=10, $page=1){

086 $params=array(

087 'id'=>$id,

088 'uid'=>$uid,

089 'page'=>$page,

090 'count'=>$count

091 );

092 return $this->api('blog.getComments', $params, 'POST');

093 }

094  

095 function api($method_name, $params, $method='GET'){

096 $params['method']=$method_name;

097 $params['v']='1.0';

098 $params['access_token']=$this->access_token;

099 $params['format']='json';

100 ksort($params);

101 $sig_str='';

102 foreach($params as $k=>$v)$sig_str.=$k.'='.$v;

103 $sig_str.=$this->client_secret;

104 $sig=md5($sig_str);

105 $params['sig']=$sig;

106 $url='http://api.renren.com/restserver.do';

107 if($method=='GET'){

108 $result=$this->http($url.'?'.http_build_query($params));

109 }else{

110 $result=$this->http($url, http_build_query($params), 'POST');

111 }

112 return $result;

113 }

114  

115 function http($url, $postfields='', $method='GET', $headers=array()){

116 $ci=curl_init();

117 curl_setopt($ci, CURLOPT_SSL_VERIFYPEER, FALSE);

118 curl_setopt($ci, CURLOPT_RETURNTRANSFER, 1);

119 curl_setopt($ci, CURLOPT_CONNECTTIMEOUT, 30);

120 curl_setopt($ci, CURLOPT_TIMEOUT, 30);

121 if($method=='POST'){

122 curl_setopt($ci, CURLOPT_POST, TRUE);

123 if($postfields!='')curl_setopt($ci, CURLOPT_POSTFIELDS, $postfields);

124 }

125 $headers[]="User-Agent: renrenPHP(piscdong.com)";

126 curl_setopt($ci, CURLOPT_HTTPHEADER, $headers);

127 curl_setopt($ci, CURLOPT_URL, $url);

128 $response=curl_exec($ci);

129 curl_close($ci);

130 $json_r=array();

131 if($response!='')$json_r=json_decode($response, true);

132 return $json_r;

133 }

134 }

[ファイル] config.php

1 <?php

2 //配置文件

3 header(&#39;Content-Type: text/html; charset=UTF-8&#39;);

4

5 $renren_k=&#39;&#39;; //人人网应用API Key

6 $renren_s=&#39;&#39;; //人人网应用Secret Key

7 $callback_url=&#39;http://yoururl/callback.php&#39;; //授权回调网址

8 $scope=&#39;publish_blog read_user_blog&#39;; //权限列表,具体权限请查看官方的api文档

9 ?>

[ファイル]index.php

01 <?php

02 session_start();

03 require_once(&#39;config.php&#39;);

04 require_once(&#39;renren.php&#39;);

05

06 $renren_t=isset($_SESSION[&#39;renren_t&#39;])?$_SESSION[&#39;renren_t&#39;]:&#39;&#39;;

07 $renren_id=isset($_SESSION[&#39;renren_id&#39;])?$_SESSION[&#39;renren_id&#39;]:&#39;&#39;;

08

09 //检查是否已登录

10 if($renren_t!=&#39;&#39; $renren_id!=&#39;&#39;){

11 $renren=new renrenPHP($renren_k, $renren_s, $renren_t);

12

13 //获取登录用户信息

14 $result=$renren->me();

15 var_dump($result);

16  

17 /**

18 //access token到期后使用refresh token刷新access token

 



声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。