.tqq.php
<?php
/**
* PHP Library for t.qq.com
*
* @author
*/
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 getMyTweet($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;
}
} 
.config.php
<?php
//配置文件
header('Content-Type: text/html; charset=UTF-8'); $tqq_k=''; //腾讯微博应用App Key
$tqq_s=''; //腾讯微博应用App Secret
$callback_url='http://yoururl/callback.php'; //授权回调网址
?> 
.index.php
<?php
session_start();
require_once('config.php');
require_once('tqq.php'); function getimgp($u){
//图片处理
$c=@file_get_contents($u);
$name=md5($u).'.jpg';
$mime='image/unknown';
return array($mime, $name, $c);
} $tqq_t=isset($_SESSION['tqq_t'])?$_SESSION['tqq_t']:'';
$tqq_id=isset($_SESSION['tqq_id'])?$_SESSION['tqq_id']:''; //检查是否已登录
if($tqq_t!='' && $tqq_id!=''){
$tqq=new tqqPHP($tqq_k, $tqq_s, $tqq_t, $tqq_id); //获取登录用户信息
$result=$tqq->me();
var_dump($result); /**
//access token到期后使用refresh token刷新access token
$result=$tqq->access_token_refresh($_SESSION['tqq_r']);
var_dump($result);
**/ /**
//发布微博
$img='http://www.baidu.com/img/baidu_sylogo1.gif';
$img_a=getimgp($img);
if($img_a[2]!=''){
$p_img=$img_a;
}else{
$p_img='';
}
$result=$tqq->postOne('微博内容', $p_img);
var_dump($result);
**/ /**
//微博列表
$result=$tqq->getMyTweet();
var_dump($result);
**/ }else{
//生成登录链接
$tqq=new tqqPHP($tqq_k, $tqq_s);
$login_url=$tqq->login_url($callback_url);
echo '<a href="',$login_url,'">点击进入授权页面</a>';
}
?> 
 .callback.php
<?php
//授权回调页面,即配置文件中的$callback_url
session_start();
require_once('config.php');
require_once('tqq.php'); if(isset($_GET['code']) && $_GET['code']!=''){
$tqq=new tqqPHP($tqq_k, $tqq_s);
$result=$tqq->access_token($callback_url, $_GET['code']);
}
if(isset($result['access_token']) && $result['access_token']!='' && isset($_GET['openid']) && $_GET['openid']!=''){
echo '授权完成,请记录<br/>access token:<input size="50" value="',$result['access_token'],'"><br/>openid:<input size="50" value="',$_GET['openid'],'"><br/>refresh token:<input size="50" value="',$result['refresh_token'],'">'; //保存登录信息,此示例中使用session保存
$_SESSION['tqq_t']=$result['access_token']; //access token
$_SESSION['tqq_id']=$_GET['openid']; //openid
$_SESSION['tqq_r']=$result['refresh_token']; //refresh token
}else{
echo '授权失败';
}
echo '<br/><a href="./">返回</a>';
?>

腾讯微博的账号登录及api操作的更多相关文章

  1. 人人网的账号登录及api操作

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

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

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

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

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

  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、新浪微博、腾讯微博等第三方登录网站的开发过程(二)

    (二).新浪微博登录 1. 首先在新浪微博开放平台注册成为开发者.[http://open.weibo.com/connect] 具体自己填写一些相关信息就OK! 2. 注册成功之后,点击[微连接], ...

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

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

  8. 第三方账号登录--QQ登录,以及QQ微博账号登录

    在QQ登陆测试的时候,刚申请正常登陆,但是由于app未上线,或许是腾讯升级造成的个别时候QQ登陆无法成功会提示下图代码,功能上没啥问题,已经达到 测试效果了.附上腾讯错误代码图(大家测试QQ登陆的时候 ...

  9. [转]QQ空间、新浪微博、腾讯微博等一键分享API链接代码

    转自------ 1.新浪微博:http://service.weibo.com/share/share.php?url= count=表示是否显示当前页面被分享数量(1显示)(可选,允许为空)&am ...

随机推荐

  1. TIMIT语音库

    TIMIT语音库有着准确的音素标注,因此可以应用于语音分割性能评价,同时该数据库又含有几百个说话人语音,所以也是评价说话人识别常用的权威语音库,但该语音库的商业用途是要花钱买的.下面的资源来自与MIT ...

  2. JavaScript工作原理和Node异步I/O

    1. 什么是JavaScript解析引擎? 简单地说,JavaScript解析引擎就是能够“读懂”JavaScript代码,并准确地给出代码运行结果的一段程序.比如var a=1+2:对于静态语言来说 ...

  3. 【leetcode】Surrounded Regions

    Surrounded Regions Given a 2D board containing 'X' and 'O', capture all regions surrounded by 'X'. A ...

  4. POJ 1979

    这是一道比较水的DPS的题目 题意就是求你可以走到的黑色的地板砖的块数,@代表你的起点,也是黑色的地板砖,#代表白色的,则说明你不能走,这就是一个广搜的题目 思路也很简单,如果你周围的那块地板是黑色的 ...

  5. Java for LeetCode 229 Majority Element II

    Given an integer array of size n, find all elements that appear more than ⌊ n/3 ⌋ times. The algorit ...

  6. 3.SpringMVC修改配置文件路径和给界面传递数据

    1.修改配置文件路径  达到  配置多文件的目的 web.xml文件中基础配置有springMVC配置的servlet路径 <servlet-name>SpringMVC</serv ...

  7. 【转】TextView长按复制实现方法小结

    有这么一个需求,用户在浏览文本信息时希望长按信息就能弹出复制的选项方便保存或者在别的页面使用这些信息.类似的, 就像长按WebView或者EditText的内容就自动弹出复制选项. 这里面主要是2个特 ...

  8. Linux内存管理原理

    本文以32位机器为准,串讲一些内存管理的知识点. 1. 虚拟地址.物理地址.逻辑地址.线性地址 虚拟地址又叫线性地址.linux没有采用分段机制,所以逻辑地址和虚拟地址(线性地址)(在用户态,内核态逻 ...

  9. 【leetcode】Best Time to Buy and Sell 2(too easy)

    Say you have an array for which the ith element is the price of a given stock on day i. Design an al ...

  10. 【Git】笔记3

    来源:廖雪峰 远程仓库 远程仓库采用github 准备工作:创建远程仓库 1.创建一个github账号 2.在本地设置ssh,获取/home/user/.ssh/id_rsa.pub内容 3.在git ...