分享一个基于Yar的WordPress微博墙插件

分享一个基于Yar的WordPress微博墙插件

基于Yar的WordPress微博墙插件

在现在移动互联网时代,微博已经成为了每个人生活中必不可少的一个社交工具。而WordPress是全世界最为流行的博客系统,把你的博客接入新浪微博,借助微博的强大用户群,不仅能给你的网站提供巨大的流量,而且还能带来不可估量价值。

WordPress微博墙就是这样的一个工具,这不是一款普通的插件,这是一款搭建在SAE基于Yar的插件。它非常的轻量,它不像其他的插件那样,提供了非常多华丽却不实用的功能,不仅臃肿而且拖慢速度。这是一款基于Yar的插件,底层C语言开发,性能卓越。而且拓展性很好,可以给你提供一下功能:

1.个人微博墙
2.发布文章同步到新浪微博
3.文章评论同步到新浪微博
接下来介绍一下基本结构:

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 夏天
*   @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);
}

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中获取数据并执行相应业务逻辑

以上就是分享一个基于Yar的WordPress微博墙插件的详细内容,更多请关注苏果儿博客其它相关文章!

© 版权声明
THE END
喜欢就支持一下吧
点赞15赞赏 分享
评论 抢沙发

请登录后发表评论

    暂无评论内容