.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. c++写入txt文件

    简单方式: #include "stdafx.h" #include <iostream> #include <iomanip> #include < ...

  2. mach 和 array 方法

  3. cf555b

    题意:按顺序给出多个互不相交的区间(表示一些小岛),和一些可以连接区间的桥,每个桥有固定的长度.区间和桥的数量都是2*10^5. 两个相邻的小岛之间的桥的长度必须小于等于最远点距离,大于等于最近点距离 ...

  4. /etc/securetty文件

    /etc/securetty 文件允许你规定“root”用户可以从哪个tty设备登录. 登录程序(通常是/bin/login)需要读取“/etc/securetty”文件. 它的格式:列出来的tty设 ...

  5. c++ vector struct 使用

    1. //test.h #include <string> using namespace std; struct AA { string a1; string a2; string a3 ...

  6. Linux下查看某一进程所占用内存的方法

    Linux下查看某一个进程所占用的内存,首先可以通过ps命令找到进程id,比如 ps -ef | grep kafka 可以看到kafka这个程序的进程id 可以看到是2913,现在可以使用如下命令查 ...

  7. MongoDB 分片的原理、搭建、应用

    一.概念: 分片(sharding)是指将数据库拆分,将其分散在不同的机器上的过程.将数据分散到不同的机器上,不需要功能强大的服务器就可以存储更多的数据和处理更大的负载.基本思想就是将集合切成小块,这 ...

  8. C# Winform中如何获取文件名与文件路径

    获取文件名方法: 用System.IO.Path.GetFileName和System.IO.Path.GetFileNameWithoutExtension(无扩展名)的方法 获取文件路径方法: / ...

  9. jQuery修改页面元素的属性

    作为一个后台开发者,在web开发的时候会常常遇到修改前台页面的属性的问题.这两天我发现jQuery的$("#id").attr("prop","值&q ...

  10. web.config中配置页面出错后跳转指定错误页面

    每当用户访问错误页面时,会出现不友好的404错误,所以为了防止这种不友好,我们在web.config中的<system.web>节点下配置 <customErrors>,在出现 ...