.kaixin.php
<?php
/**
* PHP Library for kaixin001.com
*
* @author
*/
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;
}
}

.config.php 
<?php
//配置文件
  header('Content-Type: text/html; charset=UTF-8');   $kaixin_k=''; //开心网应用API Key
  $kaixin_s=''; //开心网应用Secret Key
  $callback_url='http://yoururl/callback.php'; //授权回调网址
  $scope='create_records'; //权限列表,具体权限请查看官方的api文档
?>
3.index.php
<?php
  session_start();
  require_once('config.php');
  require_once('kaixin.php');   $kaixin_t=isset($_SESSION['kaixin_t'])?$_SESSION['kaixin_t']:''; //检查是否已登录   if($kaixin_t!=''){
  $kaixin=new kaixinPHP($kaixin_k, $kaixin_s, $kaixin_t);   //获取登录用户信息
  $result=$kaixin->me();
  var_dump($result);   /**
  //access token到期后使用refresh token刷新access token
  $result=$kaixin->access_token_refresh($_SESSION['kaixin_r']);
  var_dump($result);
  **/   /**
  //发布记录
  $img='http://www.baidu.com/img/baidu_sylogo1.gif';
  $result=$kaixin->records_add('记录内容', $img);
  var_dump($result);
  **/   }else{
  //生成登录链接
   $kaixin=new kaixinPHP($kaixin_k, $kaixin_s);
   $login_url=$kaixin->login_url($callback_url, $scope);
  echo '<a href="',$login_url,'">点击进入授权页面</a>';
  }
?>
 
 .callback.php 
<?php
//授权回调页面,即配置文件中的$callback_url
session_start();
require_once('config.php');
require_once('kaixin.php'); if(isset($_GET['code']) && $_GET['code']!=''){
$kaixin=new kaixinPHP($kaixin_k, $kaixin_s);
$result=$kaixin->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'],'"><br/>refresh token:<input size="50" value="',$result['refresh_token'],'">'; //保存登录信息,此示例中使用session保存
$_SESSION['kaixin_t']=$result['access_token']; //access token
$_SESSION['kaixin_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操作

    .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操作

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

  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. git多账号登录问题

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

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

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

  9. SourceTree 03 - 跳过账号登录直接进入主界面

    SourceTree系列第1篇 SourceTree 01 - git 客户端介绍(http://www.cnblogs.com/geaosu/p/8807666.html) SourceTree系列 ...

随机推荐

  1. splice 很好用

    splice 类似一个 copy pos 和 delete的组合拳,用起来很方便. arrayObject.splice(index,howmany,item1,.....,itemX) // ind ...

  2. (转)高性能网站架构之缓存篇—Redis集群增删节点

    标签: 高性能架构集群缓存redis 上一篇文章,我们搭建了Redis-cluster集群,这篇博客跟大家讲一下如何在一个运行的集群上增加节点或者删除节点. Redis集群添加节点 首先我们要新建立一 ...

  3. nginx 原理&知识

    2015年6月4日 17:04:20 星期四 发现两个关于nginx原理的系列文章, 非常好 http://blog.sina.com.cn/s/blog_6d579ff40100wi7p.html ...

  4. socket端口重复占用问题

    1.一个服务端进程在主动释放端口后(调用close)端口状态为TIME_WAIT,这时再去监听同样的端口,不论是否设置SO_REUSEADDR,都能监听成功,也能接收到客户端的连接,但是无法收到数据. ...

  5. perl文件句柄的传递

    perl 返回文件句柄的2种方式 1.使用 \* #!/usr/bin/perl use strict; sub openfile() { my $path=shift; open(FILE,&quo ...

  6. Effective C++ -----条款31:将文件间的编译依存关系降至最低

    支持“编译依存性最小化”的一般构想是:相依于声明式,不要相依于定义式.基于此构想的两个手段是Handle classes 和 Interface classes. 程序库头文件应该以“完全且仅有声明式 ...

  7. nyoj_31

    题目描述:五个数求最值. #include <iostream> #include <algorithm> using namespace std; int main(){ ] ...

  8. 魅族MX3\MX2 在MTP模式下恢复手机误删数据教程

    昨天帮室友的魅族mx3升级系统,结果不小心把他手机里的照片删了.但是自从flyme升级到3后,以前的U盘模式就改成了MTP模式,这样再连接电脑后就没办法用电脑上的数据恢复软件恢复数据了,因为压根就检测 ...

  9. 仿美团外卖,饿了吗 两个ListView联动,左边点击切换右边,右边滑动切换左边

    先上效果图: 实现思路: 1.先说右边标题: 首先,右边的数据源集合中的Javabean中含有三个属性name,type,title,而每个条目中会默认含有一个标题. 如果这是第一个条目,就让标题显示 ...

  10. poj 3734 Blocks 快速幂+费马小定理+组合数学

    题目链接 题意:有一排砖,可以染红蓝绿黄四种不同的颜色,要求红和绿两种颜色砖的个数都是偶数,问一共有多少种方案,结果对10007取余. 题解:刚看这道题第一感觉是组合数学,正向推了一会还没等推出来队友 ...