.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."\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;
}
} 
.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'; //授权回调网址
?>  
.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>';
}
?>  
 .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>';
?>

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

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

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

  2. 腾讯微博的账号登录及api操作

    .tqq.php <?php /** * PHP Library for t.qq.com * * @author */ class tqqPHP { function __construct( ...

  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,新浪,SNS等公众平台的登录及api操作

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

  7. **15.app后端怎么设计用户登录方案(API权限安全)

    在很多app中,都需要用户的登录操作.登录,就需要用到用户名和密码.为了安全起见,暴露明文密码的次数越少越好.怎么能最大程度避免泄露用户的密码呢?在登录后,app后端怎么去验证和维持用户的登录状态呢? ...

  8. git多账号登录问题

    作者:白狼 出处:http://www.manks.top/git-multiply-accounts.html 本文版权归作者,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文 ...

  9. 通过组策略实现Firefox自动以当前域账号登录MOSS站点---(原创)

    忘忧草原创,转发请保留本人的大名,谢谢,如果需要文档的请找我索取 前言 通过组策略实现基于AD的windows验证的sharepoint站点在火狐下自动以当前域账号登录. 操作步骤-在服务器添加策略工 ...

随机推荐

  1. VC中基于 Windows 的精确定时[转]

    在工业生产控制系统中,有许多需要定时完成的操作,如定时显示当前时间,定时刷新屏幕上的进度条,上位 机定时向下位机发送命令和传送数据等.特别是在对控制性能要求较高的实时控制系统和数据采集系统中,就更需要 ...

  2. OpenMP求完数

    源代码: #include "stdafx.h" //必须写在首行,因为其前面的include都会被忽略 #include "omp.h" #include & ...

  3. SqlServer中的Null值空值问题

    sql使用的是三值谓词逻辑,所以逻辑表达式返回的结果可以为True.False或者未知,在三值逻辑中返回True与不返回False并不完全一样, SQL对查询过滤条件的处理:接受TURE  拒绝FAL ...

  4. 64位系统运行32位Oracle程序解决方案

    Attempt to load Oracle client libraries threw BadImageFormatException. This problem will occur when ...

  5. Valid Number

    Validate if a given string is numeric. Some examples:"0" => true" 0.1 " => ...

  6. php在没用xdebug等调试工具的情况下如何让调试内容优雅地展现出来?--php数组格式化

    不知道各位猿猿们有没有碰到过类似的情况.装的PHP环境没有xdebug,而又经常用到数组.调试的时候也需要经常查看数组的结构和字段内容,用var_dump打印出来的数组内容总是杂乱无章.实在无法忍受, ...

  7. C++ 使用SQLite

    1.SQLite是一个完全独立的.不需要服务器.不要任何配置.支持SQL的.开源的文件数据库引擎.源代码和支持可以登录:http://www.sqlite.org/   1.1.下载sqlite3.d ...

  8. ASM:《X86汇编语言-从实模式到保护模式》第11章:进入保护模式

    ★PART1:进入保护模式 1. 全局描述符表(Global Descriptor Table,GDT)        32位保护模式下,如果要使用一个段,必须先登记,登记的信息包括段的起始地址,段的 ...

  9. struts2文件上传和下载

    1. struts系统中的拦截器介绍 过滤器:javaweb中的服务器组件,主要针对的请求和响应进行拦截. 拦截器:主要针对方法的调用,进行拦截器,当使用代理对象调用某个方法时候 对方法的调用进行拦截 ...

  10. ios二维码生成

    二维码扫描现在已经有很多的库可以使用了,常用的有ZXing和ZBar.如果感兴趣的同学可以自行研究. libqrencode介绍:是一个用C语言编写的用来解析二维条形码(QR Code)的程序库,li ...