新浪微博、腾讯微博、qq、人人网、开心网、网易微博、豆瓣、百度、google、微软、instagram、facebook、360、github等平台的账号登录及api操作,使用oauth 2.0
官方提供的sdk都太过庞大,这是我自己简化的,提供简单的账号登录、获取个人信息、发布微博等功能,如果需要其他功能可以根据官方的api文档自行添加
1.新浪微博
<?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_secret;
$this->access_token=$access_token;
}
function login_url($callback_url){
$params=array(
'response_type'=>'code',
'client_id'=>$this->client_id,
'redirect_uri'=>$callback_url
);
return 'https://api.weibo.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.weibo.com/oauth2/access_token';
return $this->http($url, http_build_query($params), 'POST');
}
/**
function access_token_refresh($refresh_token){
}
**/
function get_uid(){
$params=array();
$url='https://api.weibo.com/2/account/get_uid.json';
return $this->api($url, $params);
}
function show_user_by_id($uid){
$params=array(
'uid'=>$uid
);
$url='https://api.weibo.com/2/users/show.json';
return $this->api($url, $params);
}
function statuses_count($ids){
$params=array(
'ids'=>$ids
);
$url='https://api.weibo.com/2/statuses/count.json';
return $this->api($url, $params);
}
function get_comments_by_sid($id, $count=10, $page=1){
$params=array(
'id'=>$id,
'page'=>$page,
'count'=>$count
);
$url='https://api.weibo.com/2/comments/show.json';
return $this->api($url, $params);
}
function repost_timeline($id, $count=10, $page=1){
$params=array(
'id'=>$id,
'page'=>$page,
'count'=>$count
);
$url='https://api.weibo.com/2/statuses/repost_timeline.json';
return $this->api($url, $params);
}
function update($img_c, $pic=''){
$params=array(
'status'=>$img_c
);
if($pic!='' && is_array($pic)){
$url='https://api.weibo.com/2/statuses/upload.json';
$params['pic']=$pic;
}else{
$url='https://api.weibo.com/2/statuses/update.json';
}
return $this->api($url, $params, 'POST');
}
function user_timeline($uid, $count=10, $page=1){
$params=array(
'uid'=>$uid,
'page'=>$page,
'count'=>$count
);
$url='https://api.weibo.com/2/statuses/user_timeline.json';
return $this->api($url, $params);
}
function querymid($id, $type=1, $is_batch=0){
$params=array(
'id'=>$id,
'type'=>$type,
'is_batch'=>$is_batch
);
$url='https://api.weibo.com/2/statuses/querymid.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{
if(isset($params['pic'])){
uksort($params, 'strcmp');
$str_b=uniqid('------------------');
$str_m='--'.$str_b;
$str_e=$str_m. '--';
$body='';
foreach($params as $k=>$v){
if($k=='pic'){
if(is_array($v)){
$img_c=$v[2];
$img_n=$v[1];
}elseif($v{0}=='@'){
$url=ltrim($v, '@');
$img_c=file_get_contents($url);
$url_a=explode('?', basename($url));
$img_n=$url_a[0];
}
$body.=$str_m."\r\n";
$body.='Content-Disposition: form-data; name="'.$k.'"; filename="'.$img_n.'"'."\r\n";
$body.="Content-Type: image/unknown\r\n\r\n";
$body.=$img_c."\r\n";
}else{
$body.=$str_m."\r\n";
$body.='Content-Disposition: form-data; name="'.$k."\"\r\n\r\n";
$body.=$v."\r\n";
}
}
$body.=$str_e;
$headers[]="Content-Type: multipart/form-data; boundary=".$str_b;
$result=$this->http($url, $body, 'POST', $headers);
}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: sinaPHP(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.腾讯微博
<?php
/**
* PHP Library for t.qq.com
*
* @author PiscDong (http://www.piscdong.com/)
*/
class tqqPHP
{
function __construct($client_id, $client_secret, $access_token=NULL, $openid=NULL){
$this->client_id=$client_id;
$this->client_secret=$client_secret;
$this->access_token=$access_token;
$this->openid=$openid;
}
function login_url($callback_url){
$params=array(
'response_type'=>'code',
'client_id'=>$this->client_id,
'redirect_uri'=>$callback_url
);
return 'https://open.t.qq.com/cgi-bin/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://open.t.qq.com/cgi-bin/oauth2/access_token?'.http_build_query($params);
$result_str=$this->http($url);
$json_r=array();
if($result_str!='')parse_str($result_str, $json_r);
return $json_r;
}
function access_token_refresh($refresh_token){
$params=array(
'grant_type'=>'refresh_token',
'refresh_token'=>$refresh_token,
'client_id'=>$this->client_id
);
$url='https://open.t.qq.com/cgi-bin/oauth2/access_token?'.http_build_query($params);
$result_str=$this->http($url);
$json_r=array();
if($result_str!='')parse_str($result_str, $json_r);
return $json_r;
}
function me(){
$params=array();
$url='https://open.t.qq.com/api/user/info';
return $this->api($url, $params);
}
function getgetMyTweet($reqnum=10, $pageflag=0){
$params=array(
'pageflag'=>$pageflag,
'reqnum'=>$reqnum
);
$url='https://open.t.qq.com/api/statuses/broadcast_timeline';
return $this->api($url, $params);
}
function getRecount($ids){
$params=array(
'ids'=>$ids,
'flag'=>2
);
$url='https://open.t.qq.com/api/t/re_count';
return $this->api($url, $params);
}
function getReplay($id, $flag=0, $f=0, $n=10){
$params=array(
'rootid'=>$id,
'pageflag'=>$f,
'reqnum'=>$n,
'flag'=>$flag
);
$url='https://open.t.qq.com/api/t/re_list';
return $this->api($url, $params);
}
function postOne($img_c, $pic=''){
$params=array(
'content'=>$img_c
);
if($pic!='' && is_array($pic)){
$url='https://open.t.qq.com/api/t/add_pic';
$params['pic']=$pic;
}else{
$url='https://open.t.qq.com/api/t/add';
}
return $this->api($url, $params, 'POST');
}
function api($url, $params, $method='GET'){
$params['oauth_consumer_key']=$this->client_id;
$params['access_token']=$this->access_token;
$params['openid']=$this->openid;
$params['clientip']=$this->getIP();
$params['oauth_version']='2.a';
$params['format']='json';
$params['scope']='all';
if($method=='GET'){
$result_str=$this->http($url.'?'.http_build_query($params));
}else{
if(isset($params['pic'])){
uksort($params, 'strcmp');
$str_b=uniqid('------------------');
$str_m='--'.$str_b;
$str_e=$str_m. '--';
$body='';
foreach($params as $k=>$v){
if($k=='pic'){
if(is_array($v)){
$img_c=$v[2];
$img_n=$v[1];
}elseif($v{0}=='@'){
$url=ltrim($v, '@');
$img_c=file_get_contents($url);
$url_a=explode('?', basename($url));
$img_n=$url_a[0];
}
$body.=$str_m."\r\n";
$body.='Content-Disposition: form-data; name="'.$k.'"; filename="'.$img_n.'"'."\r\n";
$body.="Content-Type: image/unknown\r\n\r\n";
$body.=$img_c."\r\n";
}else{
$body.=$str_m."\r\n";
$body.='Content-Disposition: form-data; name="'.$k."\"\r\n\r\n";
$body.=$v."\r\n";
}
}
$body.=$str_e;
$headers[]="Content-Type: multipart/form-data; boundary=".$str_b;
$result_str=$this->http($url, $body, 'POST', $headers);
}else{
$result_str=$this->http($url, http_build_query($params), 'POST');
}
}
$json_r=array();
if($result_str!='')$json_r=json_decode($result_str, true);
return $json_r;
}
function getIP(){
if(isset($_ENV['HTTP_CLIENT_IP'])){
$ip=$_ENV['HTTP_CLIENT_IP'];
}elseif(isset($_ENV['HTTP_X_FORWARDED_FOR'])){
$ip=$_ENV['HTTP_X_FORWARDED_FOR'];
}elseif(isset($_ENV['REMOTE_ADDR'])){
$ip=$_ENV['REMOTE_ADDR'];
}else{
$ip=$_SERVER['REMOTE_ADDR'];
}
if(strstr($ip, ':')){
$ipa=explode(':', $ip);
foreach($ipa as $v){
if(strlen($v)>7)$ip=$v;
}
}
if(strlen($ip)<7)$ip='0.0.0.0';
return $ip;
}
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: tqqPHP(piscdong.com)";
curl_setopt($ci, CURLOPT_HTTPHEADER, $headers);
curl_setopt($ci, CURLOPT_URL, $url);
$response=curl_exec($ci);
curl_close($ci);
return $response;
}
}3.qq
<?php
/**
* PHP Library for qq.com
*
* @author PiscDong (http://www.piscdong.com/)
*/
class qqPHP
{
function __construct($appid, $appkey, $access_token=NULL){
$this->appid=$appid;
$this->appkey=$appkey;
$this->access_token=$access_token;
}
function login_url($callback_url, $scope=''){
$params=array(
'client_id'=>$this->appid,
'redirect_uri'=>$callback_url,
'response_type'=>'code',
'scope'=>$scope
);
return 'https://graph.qq.com/oauth2.0/authorize?'.http_build_query($params);
}
function access_token($callback_url, $code){
$params=array(
'grant_type'=>'authorization_code',
'client_id'=>$this->appid,
'client_secret'=>$this->appkey,
'code'=>$code,
'state'=>'',
'redirect_uri'=>$callback_url
);
$url='https://graph.qq.com/oauth2.0/token?'.http_build_query($params);
$result_str=$this->http($url);
$json_r=array();
if($result_str!='')parse_str($result_str, $json_r);
return $json_r;
}
/**
function access_token_refresh($refresh_token){
}
**/
function get_openid(){
$params=array(
'access_token'=>$this->access_token
);
$url='https://graph.qq.com/oauth2.0/me?'.http_build_query($params);
$result_str=$this->http($url);
$json_r=array();
if($result_str!=''){
preg_match('/callback\(\s+(.*?)\s+\)/i', $result_str, $result_a);
$json_r=json_decode($result_a[1], true);
}
return $json_r;
}
function get_user_info($openid){
$params=array(
'openid'=>$openid
);
$url='https://graph.qq.com/user/get_user_info';
return $this->api($url, $params);
}
function add_share($openid, $title, $url, $site, $fromurl, $images='', $summary=''){
$params=array(
'openid'=>$openid,
'title'=>$title,
'url'=>$url,
'site'=>$site,
'fromurl'=>$fromurl,
'images'=>$images,
'summary'=>$summary
);
$url='https://graph.qq.com/share/add_share';
return $this->api($url, $params, 'POST');
}
function api($url, $params, $method='GET'){
$params['access_token']=$this->access_token;
$params['oauth_consumer_key']=$this->appid;
$params['format']='json';
if($method=='GET'){
$result_str=$this->http($url.'?'.http_build_query($params));
}else{
$result_str=$this->http($url, http_build_query($params), 'POST');
}
$result=array();
if($result_str!='')$result=json_decode($result_str, true);
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: qqPHP(piscdong.com)";
curl_setopt($ci, CURLOPT_HTTPHEADER, $headers);
curl_setopt($ci, CURLOPT_URL, $url);
$response=curl_exec($ci);
curl_close($ci);
return $response;
}
}4.人人网
<?php
/**
* PHP Library for renren.com
*
* @author PiscDong (http://www.piscdong.com/)
*/
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;
}
}5.开心网
<?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;
}
}6.网易微博
<?php
/**
* PHP Library for t.163.com
*
* @author PiscDong (http://www.piscdong.com/)
*/
class t163PHP
{
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){
$params=array(
'response_type'=>'code',
'client_id'=>$this->client_id,
'redirect_uri'=>$callback_url
);
return 'https://api.t.163.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.t.163.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.t.163.com/oauth2/access_token';
return $this->http($url, http_build_query($params), 'POST');
}
function me(){
$params=array();
$url='https://api.t.163.com/users/show.json';
return $this->api($url, $params);
}
function user_timeline($id, $count=10){
$params=array(
'user_id'=>$id,
'count'=>$count
);
$url='https://api.t.163.com/statuses/user_timeline.json';
return $this->api($url, $params);
}
function update($status){
$params=array(
'status'=>$status
);
$url='https://api.t.163.com/statuses/update.json';
return $this->api($url, $params, 'POST');
}
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: t163PHP(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;
}
}7.豆瓣
<?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;
}
}8.百度
<?php
/**
* PHP Library for baidu.com
*
* @author PiscDong (http://www.piscdong.com/)
*/
class baiduPHP
{
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()),
'display'=>'page'
);
return 'https://openapi.baidu.com/oauth/2.0/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://openapi.baidu.com/oauth/2.0/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://openapi.baidu.com/oauth/2.0/token';
return $this->http($url, http_build_query($params), 'POST');
}
function user(){
$params=array();
$url='https://openapi.baidu.com/rest/2.0/passport/users/getLoggedInUser';
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: baiduPHP(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;
}
}9.google
<?php
/**
* PHP Library for google.com
*
* @author PiscDong (http://www.piscdong.com/)
*/
class googlePHP
{
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'=>'profile',
'access_type'=>'offline'
);
return 'https://accounts.google.com/o/oauth2/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://accounts.google.com/o/oauth2/token';
$result=$this->http($url, http_build_query($params), 'POST');
return $result;
}
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://accounts.google.com/o/oauth2/token';
$result=$this->http($url, http_build_query($params), 'POST');
return $result;
}
function me(){
$params=array();
$url='https://www.googleapis.com/oauth2/v1/userinfo';
return $this->api($url, $params);
}
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: google(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;
}
}10微软
<?php
/**
* PHP Library for live.com
*
* @author PiscDong (http://www.piscdong.com/)
*/
class livePHP
{
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://login.live.com/oauth20_authorize.srf?'.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://login.live.com/oauth20_token.srf';
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_secret'=>$this->client_secret,
'client_id'=>$this->client_id
);
$url='https://login.live.com/oauth20_token.srf';
return $this->http($url, http_build_query($params), 'POST');
}
function me(){
$params=array();
$url='https://apis.live.net/v5.0/me';
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: livePHP(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;
}
}11.instagram
<?php
/**
* PHP Library for instagram.com
*
* @author PiscDong (http://www.piscdong.com/)
*/
class instagramPHP
{
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){
$params=array(
'response_type'=>'code',
'client_id'=>$this->client_id,
'redirect_uri'=>$callback_url
);
return 'https://api.instagram.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://api.instagram.com/oauth/access_token';
return $this->http($url, http_build_query($params), 'POST');
}
/**
function access_token_refresh($refresh_token){
}
**/
function user($id){
$params=array();
$url='https://api.instagram.com/v1/users/'.$id.'/';
return $this->api($url, $params);
}
function user_media($id, $count=10, $max_id=''){
$params=array(
'count'=>$count
);
if($max_id!='')$params['max_id']=$max_id;
$url='https://api.instagram.com/v1/users/'.$id.'/media/recent/';
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: instagramPHP(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;
}
}12.facebook
<?php
/**
* PHP Library for facebook.com
*
* @author PiscDong (http://www.piscdong.com/)
*/
class facebookPHP
{
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.facebook.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.facebook.com/oauth/access_token';
return $this->http($url, http_build_query($params), 'POST');
}
/**
function access_token_refresh($refresh_token){
}
**/
function me(){
$params=array();
$url='https://graph.facebook.com/me';
return $this->api($url, $params);
}
function my_feed($count=10, $page=1){
$params=array(
'page'=>$page,
'count'=>$count
);
$url='https://graph.facebook.com/me/feed';
return $this->api($url, $params);
}
function update($content){
$params=array(
'message'=>$content
);
$url='https://graph.facebook.com/me/feed/';
return $this->api($url, $params, 'POST');
}
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: facebookPHP(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;
}
}13.360
<?php
/**
* PHP Library for 360.cn
*
* @author PiscDong (http://www.piscdong.com/)
*/
class o360PHP
{
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){
$params=array(
'response_type'=>'code',
'client_id'=>$this->client_id,
'redirect_uri'=>$callback_url
);
return 'https://openapi.360.cn/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://openapi.360.cn/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://openapi.360.cn/oauth2/access_token';
return $this->http($url, http_build_query($params), 'POST');
}
function me(){
$params=array();
$url='https://openapi.360.cn/user/me.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: o360PHP(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;
}
}14.github
<?php
/**
* PHP Library for github.com
*
* @author PiscDong (http://www.piscdong.com/)
*/
class githubPHP
{
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(
'client_id'=>$this->client_id,
'redirect_uri'=>$callback_url,
'scope'=>$scope
);
return 'https://github.com/login/oauth/authorize?'.http_build_query($params);
}
function access_token($callback_url, $code){
$params=array(
'code'=>$code,
'client_id'=>$this->client_id,
'client_secret'=>$this->client_secret,
'redirect_uri'=>$callback_url
);
$url='https://github.com/login/oauth/access_token';
$result_str=$this->http($url, http_build_query($params), 'POST');
$json_r=array();
if($result_str!='')parse_str($result_str, $json_r);
return $json_r;
}
/**
function access_token_refresh($refresh_token){
}
**/
function me(){
$params=array();
$url='https://api.github.com/user';
return $this->api($url, $params);
}
function api($url, $params, $method='GET'){
$params['access_token']=$this->access_token;
if($method=='GET'){
$result_str=$this->http($url.'?'.http_build_query($params));
}else{
$result_str=$this->http($url, http_build_query($params), 'POST');
}
$result=array();
if($result_str!='')$result=json_decode($result_str, true);
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: githubPHP(piscdong.com)";
curl_setopt($ci, CURLOPT_HTTPHEADER, $headers);
curl_setopt($ci, CURLOPT_URL, $url);
$response=curl_exec($ci);
curl_close($ci);
return $response;
}
}15.示例文件,以新浪微博为例,其他平台方法类似
/**
* 示例文件,以新浪微博为例,其他平台方法类似
*/
//生成登录链接
require_once('sina.php');
$app_key=''; //新浪微博应用App Key
$app_secret=''; //新浪微博应用App Secret
$callback_url='http://yoururl/sina_callback.php'; //回调网址,请根据自己的实际情况修改
$sina=new sinaPHP($app_key, $app_secret);
$login_url=$sina->login_url($callback_url); //生成登录链接,部分平台需要权限,格式请参考各平台api文档
echo '<a href="'.$login_url.'">点击进入授权页面</a>';
//授权回调页面,即生成登录链接时的$callback_url
require_once('sina.php');
$app_key=''; //新浪微博应用App Key
$app_secret=''; //新浪微博应用App Secret
$callback_url='http://yoururl/sina_callback.php'; //回调网址,必须和生成登录链接时相同
if(isset($_GET['code']) && $_GET['code']!=''){
$sina=new sinaPHP($app_key, $app_secret);
$result=$sina->access_token($callback_url, $_GET['code']); //获取access token
/**
* $result['access_token'],用户access token
* $result['expires_in'],access token的有效期,单位:秒
* 部分平台会有$result['refresh_token'],refresh token,access token到期后使用refresh token生成新的access token
* 腾讯微博还需要保存$_GET['openid']
*/
}
//用户登录授权后操作api
require_once('sina.php');
$app_key=''; //新浪微博应用App Key
$app_secret=''; //新浪微博应用App Secret
$access_token=''; //授权回调页面生成的用户access token
$sina=new sinaPHP($app_key, $app_secret, $access_token); //腾讯微博还需要openid,授权回调页面保存的$_GET['openid']
$sina_uid=$sina->get_uid(); //登录用户uid
//其他功能请参考sina.php自行使用,或者根据api文档自行添加
//其他平台的使用方法和新浪微博类似,各种api的返回数据格式各有不同,请自行参考各平台的api文档
//支持refresh token的平台在access token到期后请使用access_token_refresh()生成新的access token
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号