首页 >php教程 >PHP源码 >新浪微博的账号登录及api操作

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

PHP中文网
PHP中文网原创
2016-05-25 17:06:551538浏览

新浪微博的账号登录及api操作,使用oauth 2.0 
官方提供的sdk都太过庞大,这是我自己简化的,提供简单的账号登录、获取个人信息、发布分享等功能,如果需要其他功能可以根据官方的api文档自行添加

更新:修改index.php中的bug;如果要使用session,请在index.php和callback.php中添加“session_start();”

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_secret;
        $this->access_token=$access_token;
    }
 
    function login_url($callback_url){
        $params=array(
            &#39;response_type&#39;=>&#39;code&#39;,
            &#39;client_id&#39;=>$this->client_id,
            &#39;redirect_uri&#39;=>$callback_url
        );
        return &#39;https://api.weibo.com/oauth2/authorize?&#39;.http_build_query($params);
    }
 
    function access_token($callback_url, $code){
        $params=array(
            &#39;grant_type&#39;=>&#39;authorization_code&#39;,
            &#39;code&#39;=>$code,
            &#39;client_id&#39;=>$this->client_id,
            &#39;client_secret&#39;=>$this->client_secret,
            &#39;redirect_uri&#39;=>$callback_url
        );
        $url=&#39;https://api.weibo.com/oauth2/access_token&#39;;
        return $this->http($url, http_build_query($params), &#39;POST&#39;);
    }
 
    /**
    function access_token_refresh($refresh_token){
    }
    **/
 
    function get_uid(){
        $params=array();
        $url=&#39;https://api.weibo.com/2/account/get_uid.json&#39;;
        return $this->api($url, $params);
    }
 
    function show_user_by_id($uid){
        $params=array(
            &#39;uid&#39;=>$uid
        );
        $url=&#39;https://api.weibo.com/2/users/show.json&#39;;
        return $this->api($url, $params);
    }
 
    function statuses_count($ids){
        $params=array(
            &#39;ids&#39;=>$ids
        );
        $url=&#39;https://api.weibo.com/2/statuses/count.json&#39;;
        return $this->api($url, $params);
    }
 
    function get_comments_by_sid($id, $count=10, $page=1){
        $params=array(
            &#39;id&#39;=>$id,
            &#39;page&#39;=>$page,
            &#39;count&#39;=>$count
        );
        $url=&#39;https://api.weibo.com/2/comments/show.json&#39;;
        return $this->api($url, $params);
    }
 
    function repost_timeline($id, $count=10, $page=1){
        $params=array(
            &#39;id&#39;=>$id,
            &#39;page&#39;=>$page,
            &#39;count&#39;=>$count
        );
        $url=&#39;https://api.weibo.com/2/statuses/repost_timeline.json&#39;;
        return $this->api($url, $params);
    }
 
    function update($img_c, $pic=&#39;&#39;){
        $params=array(
            &#39;status&#39;=>$img_c
        );
        if($pic!=&#39;&#39; && is_array($pic)){
            $url=&#39;https://api.weibo.com/2/statuses/upload.json&#39;;
            $params[&#39;pic&#39;]=$pic;
        }else{
            $url=&#39;https://api.weibo.com/2/statuses/update.json&#39;;
        }
        return $this->api($url, $params, &#39;POST&#39;);
    }
 
    function user_timeline($uid, $count=10, $page=1){
        $params=array(
            &#39;uid&#39;=>$uid,
            &#39;page&#39;=>$page,
            &#39;count&#39;=>$count
        );
        $url=&#39;https://api.weibo.com/2/statuses/user_timeline.json&#39;;
        return $this->api($url, $params);
    }
 
    function querymid($id, $type=1, $is_batch=0){
        $params=array(
            &#39;id&#39;=>$id,
            &#39;type&#39;=>$type,
            &#39;is_batch&#39;=>$is_batch
        );
        $url=&#39;https://api.weibo.com/2/statuses/querymid.json&#39;;
        return $this->api($url, $params);
    }
 
    function api($url, $params, $method=&#39;GET&#39;){
        $params[&#39;access_token&#39;]=$this->access_token;
        if($method==&#39;GET&#39;){
            $result=$this->http($url.&#39;?&#39;.http_build_query($params));
        }else{
            if(isset($params[&#39;pic&#39;])){
                uksort($params, &#39;strcmp&#39;);
                $str_b=uniqid(&#39;------------------&#39;);
                $str_m=&#39;--&#39;.$str_b;
                $str_e=$str_m. &#39;--&#39;;
                $body=&#39;&#39;;
                foreach($params as $k=>$v){
                    if($k==&#39;pic&#39;){
                        if(is_array($v)){
                            $img_c=$v[2];
                            $img_n=$v[1];
                        }elseif($v{0}==&#39;@&#39;){
                            $url=ltrim($v, &#39;@&#39;);
                            $img_c=file_get_contents($url);
                            $url_a=explode(&#39;?&#39;, basename($url));
                            $img_n=$url_a[0];
                        }
                        $body.=$str_m."\r\n";
                        $body.=&#39;Content-Disposition: form-data; name="&#39;.$k.&#39;"; filename="&#39;.$img_n.&#39;"&#39;."\r\n";
                        $body.="Content-Type: image/unknown\r\n\r\n";
                        $body.=$img_c."\r\n";
                    }else{
                        $body.=$str_m."\r\n";
                        $body.=&#39;Content-Disposition: form-data; name="&#39;.$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, &#39;POST&#39;, $headers);
            }else{
                $result=$this->http($url, http_build_query($params), &#39;POST&#39;);
            }
        }
        return $result;
    }
 
    function http($url, $postfields=&#39;&#39;, $method=&#39;GET&#39;, $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==&#39;POST&#39;){
            curl_setopt($ci, CURLOPT_POST, TRUE);
            if($postfields!=&#39;&#39;)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!=&#39;&#39;)$json_r=json_decode($response, true);
        return $json_r;
    }
}

config.php

<?php
//配置文件
header(&#39;Content-Type: text/html; charset=UTF-8&#39;);
 
$sina_k=&#39;&#39;; //新浪微博应用App Key
$sina_s=&#39;&#39;; //新浪微博应用App Secret
$callback_url=&#39;http://yoururl/callback.php&#39;; //授权回调网址
?>

index.php

<?php
session_start(); //此示例中要使用session
require_once(&#39;config.php&#39;);
require_once(&#39;sina.php&#39;);
 
function getimgp($u){
    //图片处理
    $c=@file_get_contents($u);
    $name=md5($u).&#39;.jpg&#39;;
    $mime=&#39;image/unknown&#39;;
    return array($mime, $name, $c);
}
 
$sina_t=isset($_SESSION[&#39;sina_t&#39;])?$_SESSION[&#39;sina_t&#39;]:&#39;&#39;;
 
//检查是否已登录
if($sina_t!=&#39;&#39;){
    $sina=new sinaPHP($sina_k, $sina_s, $sina_t);
 
    //获取登录用户id
    $sina_uid=$sina->get_uid();
    $uid=$sina_uid[&#39;uid&#39;];
 
    //获取登录用户信息
    $result=$sina->show_user_by_id($uid);
    var_dump($result);
 
    /**
    //发布微博
    $content=&#39;微博内容&#39;;
    $img=&#39;http://www.baidu.com/img/baidu_sylogo1.gif&#39;;
    $img_a=getimgp($img);
    if($img_a[2]!=&#39;&#39;){
        $result=$sina->update($content, $img_a);
        //发布带图片微博
    }else{
        $result=$sina->update($content);
        //发布纯文字微博
    }
    var_dump($result);
    **/
 
    /**
    //微博列表
    $result=$sina->user_timeline($uid);
    var_dump($result);
    **/
 
}else{
    //生成登录链接
    $sina=new sinaPHP($sina_k, $sina_s);
    $login_url=$sina->login_url($callback_url);
    echo &#39;<a href="&#39;,$login_url,&#39;">点击进入授权页面</a>&#39;;
}
?>

4.callback.php

<?php
//授权回调页面,即配置文件中的$callback_url
session_start(); //此示例中要使用session
require_once(&#39;config.php&#39;);
require_once(&#39;sina.php&#39;);
 
if(isset($_GET[&#39;code&#39;]) && $_GET[&#39;code&#39;]!=&#39;&#39;){
    $o=new sinaPHP($sina_k, $sina_s);
    $result=$o->access_token($callback_url, $_GET[&#39;code&#39;]);
}
if(isset($result[&#39;access_token&#39;]) && $result[&#39;access_token&#39;]!=&#39;&#39;){
    echo &#39;授权完成,请记录<br/>access token:<input size="50" value="&#39;,$result[&#39;access_token&#39;],&#39;">&#39;;
 
    //保存登录信息,此示例中使用session保存
    $_SESSION[&#39;sina_t&#39;]=$result[&#39;access_token&#39;]; //access token
}else{
    echo &#39;授权失败&#39;;
}
echo &#39;<br/><a href="./">返回</a>&#39;;
?>
声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn