网站调用新浪微博内容(PHP中定义6服务端回调操作封装与微博开放平台通信获取用户AccessToken)
优采云 发布时间: 2021-12-26 04:03网站调用新浪微博内容(PHP中定义6服务端回调操作封装与微博开放平台通信获取用户AccessToken)
接下来介绍一下基本结构:
1 核心数据操作类
这个类在Dao.class.php文件中,是插件的核心,负责从服务器获取数据
/**
*
* 用户数据获取类
* @author 夏天
* @date 2015年6月28日
* @site http://www.xtwind.com
*
*/
class Dao{
/**
* 微博RPC操作对象
*/
private $client;
/**
* 用户标识
*/
private $mark;
/**
* 构造函数设置用户标识
*/
function __construct($state);
/**
* 返回用户标识
*/
public function getMark();
/**
* 启用插件
* @return 成功返回true,失败返回认证地址
*/
public function run();
/**
* 获取授权情况
* @return string 返回过期时间,未登录或者过期返回false
*/
public function getAuthOver();
/**
* 删除授权
* @return boolean
*/
public function delAuth();
/**
* 获取认证跳转url
* @return string
*/
public function getAuthUrl();
/**
* 获取用户微博列表
* @return array
*/
public function getWeibo();
/**
* 获取用户基本信息
* @return array
*/
public function getUser();
/**
* 发布微博
* @return Array 返回微博数据数组
*/
public function weiboPub($content,$imgUrl=null);
/**
* 删除微博
* @param int 微博ID
* @return Array 返回被删除微博数据数组
*/
public function weiboDel($weiboID);
/**
* 发布一条评论过
* @param int 微博ID
* @param string 评论内容
* @return array 评论相关数组
*/
public function sendComment($id,$comment);
/**
* 关注一个用户
* @param 用户ID或者名字
* @return 返回关注者信息
*/
public function followUser($user);
/**
* 转发微博
* @param int 微博id
* @param string 添加的内容
*/
public function forwardWeibo($id,$text=null);
}
2 插件实体类
该类是插件的实体,定义在Plugins.class.php中,负责调用Dao类实现各种功能,包括输入输出、用户配置、授权管理
/**
* 插件实体类
* @Author:Summer
* @data: 2015-06-28
* @site: http://www.xtwind.com
*/
class Plugins{
/**
* 数据获取类对象
*/
private $dao;
/**
* 插件显示别名
*/
private $slug = 'weibo-wall';
/**
* 插件页url
*/
private $plugUrl ;
/*
* 插件构造
* @param 用户数据操作类
*/
public function __construct(Dao $obj);
/**
* 启用插件,注册钩子,调用用户函数,删除授权,发表微博
* @param array 插件设置选项关联数组,key必须为对应的操作方法,该数组中的键会被注册为wordpress相应钩子
* @param array 需要过滤的动作,该数组中键不会被注册为钩子,但是会作为方法被调用,值为方法的参数
*/
public function run($arr1=null,$arr2=null);
/**
* 插件主页显示
*/
public function display_function();
/**
* 新文章同步发布微博
* @param int 文章ID
*/
public function publish_post($postID);
/**
* 删除文章同步删除微博
* @param int 文章ID
*/
public function before_delete_post($postID);
/**
* 收到评论同步到微博评论
* @param id 评论id
*/
public function comment_post($commentID);
/**
* 关注作者
*/
public function follow_author($userid);
/**
* 用户微博数据获取
*/
public function weiboOuput( $atts=null, $content = null );
/**
* 数据页面输出
*/
public function showWeibo();
/**
* 图片URL处理
* @param string
*/
private function getOriginalUrl($url);
/**
* 时间转换
* @param string
*/
private function Sec2Time($time);
/**
* 插件设置key获取
* @param string 需要设置的key
*/
private function setting_key($key,$func=false);
/**
* 插件设置value获取
* @param string 需要获取的value
*/
private function get_setting($key,$func=false);
/**
* 插件设置删除
*/
private function del_setting();
/**
* 提示信息
* @param string
*/
private function noticeMsg($msg);
}
3 服务器认证操作
该接口定义了用户认证所需的所有操作,包括获取授权、删除授权、查看授权等,定义在AuthDao.php
/**
* 认证操作类接口
* @author 夏天
* @date 2015年6月18日
* @site http://www.xtwind.com
*/
interface AuthDao{
/**
* 设置用户AccessToken
* @return boolean
*/
public function setAccessToken();
/**
* 获取用户AccessToken
* @return String
*/
public function getAccessToken();
/**
* 删除用户AccessToken
* @return boolean
*/
public function delAccessToken();
/**
* 判断用户AccessToken是否存在
* @return boolean
*/
public function isLogin();
/**
* 获取认证跳转url
* @return string
*/
public function getAuthUrl();
/**
* 授权过期时间
* @return string
*/
public function getAuthOver();
}
4 服务器端微博操作
该接口定义了所有与用户微博操作相关的方法,包括发布微博、阅读微博、阅读信息、删除微博等,定义在 WeiboDao.php
/**
* 微博操作类接口
* @author 夏天
* @date 2015年6月18日
* @site http://www.xtwind.com
*/
interface WeiboDao {
/**
* 获取用户微博信息列表
* @param int 获取数量
* @param int 类型过滤 0:全部、1:原创、2:图片、3:视频、4:音乐,默认为0。
* @return String
*/
public function getWeibo();
/**
* 获取用户基本信息
* @return Array
*/
public function getUser();
/**
* 发布微博
* @return Array 返回微博数据数组
*/
public function weiboPub($content,$imgUrl);
/**
* 删除微博
* @return Array 返回被删除微博数据数组
*/
public function weiboDel($weiboID);
/**
* 发布一条评论
* @param integer 微博ID
* @param string 评论内容
*/
public function sendComment($id,$comment);
/**
* 关注一个用户
* @param 用户ID或者名字
* @return 返回关注者信息
*/
public function followUser($user);
/**
* 转发微博
* @param int 微博id
* @param string 添加的信息
*/
public function forwardWeibo($id,$text=null);
}
5 服务器端数据提供接口
该接口负责向客户端提供数据,以及客户端需要的一些操作,继承自微博操作接口,在APIDao.php中定义
/**
* 对外提供服务类接口,继承于微博操作接口
* @author 夏天
* @date 2015年6月18日
* @site http://www.xtwind.com
*/
interface DaoAPI extends WeiboDao{
/**
* 删除用户AccessToken
* @return boolean
*/
public function delAccessToken();
/**
* 判断用户AccessToken是否存在
* @return boolean
*/
public function isLogin();
/**
* 获取认证跳转url
* @return string
*/
public function getAuthUrl();
/**
* 授权过期时间
* @return string
*/
public function getAuthOver();
}
6 服务器回调操作
这种封装在获取用户的AccessToken后与微博开放平台通信获取回调操作
class Callback {
/**
* 微博认证类对象
*/
private $authObj;
/**
* 构造函数
* @param AuthDaoImpl 微博认证对象
*/
public function __construct(AuthDaoImpl $obj);
/**
* 认证回调操作,保存AccessToken
* @return boolean
*/
public function callback();
}
7 服务器应用入口
入口主要是分发回调请求和创建RPC实例
if($_GET['code']){
$keys = array(
'code' => $_GET['code'],
'redirect_uri' => APP_CALLBACK
);
$back = new Callback(new AuthDaoImpl($_GET['state'],$keys));
if($back->callback()){
header('Location: '.$_GET['state'].'/wp-admin/options-general.php?page=weibo-wall');
}
exit;
}
if($_GET['user']){
$server = new Yar_Server(new API($_GET['user']));
try{
$server->handle();
}catch(Exception $e){
echo "感谢您使用微博墙!";
}
}
7 客户端应用入口
此条目实例化插件实体类并启用插件
$plu = new Plugins(new Dao(get_bloginfo( 'url' )));
$plu -> run(get_option('weibo_wall'),get_option('weibo_func'));
8 总结
整个流程是这样的,业务逻辑很简单,代码也很容易理解。在使用的过程中,我发现Yar真的很简单实用,而且是可以并行的。不过这里没有体现出来,可以做一些优化。插件的客户端依赖于Yar框架,是基于C语言开发的扩展。但是如果你没有框架扩展也没关系。我们已经给出了 Yar 的纯 PHP 实现。不用注意就可以使用,但还是推荐大家使用Yar。
插件在设计时只提供了几个功能,但是有些人需要其他功能,我该怎么办?这方面我们也考虑过,所以在设计的时候插件的扩展性很好,但是需要有一定的PHP编程技巧。
如何扩展他的功能?
1.联系作者,告诉你你需要的功能
2.作者开发了相应的数据API
3.你在Dao.class.php本地调用API
4.在Plugins.class.php中获取数据并执行相应的业务逻辑