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


    1.sina.php

    <?php
    /**
     * PHP Library for weibo.com
     *
     * @author 
     */
    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."
    ";
                            $body.='Content-Disposition: form-data; name="'.$k.'"; filename="'.$img_n.'"'."
    ";
                            $body.="Content-Type: image/unknown
    
    ";
                            $body.=$img_c."
    ";
                        }else{
                            $body.=$str_m."
    ";
                            $body.='Content-Disposition: form-data; name="'.$k.""
    
    ";
                            $body.=$v."
    ";
                        }
                    }
                    $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.config.php

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

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

    4.backcall.php

    <?php
    //授权回调页面,即配置文件中的$callback_url
    session_start(); //此示例中要使用session
    require_once('config.php');
    require_once('sina.php');
     
    if(isset($_GET['code']) && $_GET['code']!=''){
        $o=new sinaPHP($sina_k, $sina_s);
        $result=$o->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'],'">';
     
        //保存登录信息,此示例中使用session保存
        $_SESSION['sina_t']=$result['access_token']; //access token
    }else{
        echo '授权失败';
    }
    echo '<br/><a href="./">返回</a>';
    ?>
  • 相关阅读:
    《分析服务从入门到精通读书笔记》第四章、维度部署浏览篇(3)
    集群(cluster)原理(转)
    Atitit 前端测试最简化内嵌web服务器 php 与node.js 目录 1.1. php内置Web Server 1 1.2. Node的 2 Node的比较麻烦些。。Php更加简单
    Atitit mybatis使用简明教程 目录 1.1. Mybatis.xml 配置文件 1 1.2. Datamp.xml mapper文件主要作用是分模块放sql语句 2 1.3. 查询
    Atitit 业务流程执行引擎的实现 目录 1.1. 引擎实现语言java js php等 1 1.2. 流程语言 xml sql js等 业务流程定义语言规范总结 1 1.3. 实体方法定义 2
    Atitit 常见软件设计图纸总结 目录 1.1. ui原型图与html 2 1.2. 业务逻辑 伪代码 各种uml图 2 1.3. 总体设计图纸 结构图 层次图 架构图 2 1.4. 业务逻辑
    Atitit velocity 模板引擎使用法 目录 1.1. 1.4 Context 1 1.1.1. 1.4.1 Context 基本概念 1 1.2. .3不同模式下使用velocity 1
    Atitit mysql存储过程编写指南 1. 定义变量 1 1.1. 变量名以@开头用户变量 会话变量 1 1.2. 以declare关键字声明 存储过程变量 2 1.3. @是用户自定义变量,
    Atitit 算法的艺术 attilax艾提拉著v7 t88.docx Atitit 算法之道 attilax著 1. 文本方面的编码算法 3 1.1. Base64 htmlencode url
    Atitt 常见的拖欠费用的公司与个人黑名单 陕西西部安全网 20072008 西安 一个月 25000 西安盛世涅槃 2007 西安 1m 25000 Sicyi msc 2007 n
  • 原文地址:https://www.cnblogs.com/qhorse/p/4844175.html
Copyright © 2020-2023  润新知