php redis实现文章发布系统(用户投票系统)

开发技术 作者: 2024-08-17 03:50:01
这篇文章主要为大家详细介绍了php redis实现文章发布系统以及用户投票系统,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了PHP实现文章发布系统、用户投票系统的具体代码,供大家参考,具体内容如下

redis; $key= "queue"; $ONE_WEEK_IN_SECONDS= 7*86400; $redis -> multi($key); //生成新的文章id $article_id = $redis -> incr("article:",$key);
//<a href="https://www.jb51.cc/tag/wenzhang/" target="_blank" class="keywords">文章</a>已投票<a href="https://www.jb51.cc/tag/yonghuming/" target="_blank" class="keywords">用户名</a>单
$voted = "voted:".$article_id;
$this->redis->sadd($voted,$user,$key);
//设置过期时间(为1周)
$this->redis->expipre($voted,$ONE_WEEK_IN_SECONDS,$key);

//<a href="https://www.jb51.cc/tag/huoqu/" target="_blank" class="keywords">获取</a>现在的时间
$now =time();
$article = "article:".$article_id;
$data = ['title'=>'测试1','link'=>'www.hahaha.com','poster'=>$user,'tine'=>$now,'votes'=>1];
//$data = json_encode($data);
$redis -> hmset($article,$data,$key);

//将<a href="https://www.jb51.cc/tag/wenzhang/" target="_blank" class="keywords">文章</a><a href="https://www.jb51.cc/tag/tianjia/" target="_blank" class="keywords">添加</a>到根据时间排序有序集合和根据评分排序有序结合中
$this -> redis -> zadd("<a href="https://www.jb51.cc/tag/score/" target="_blank" class="keywords">score</a>:",1,$article,$key);
$this -> redis -> zadd("time:",$now,$key);

$redis -> exec($key);

}

<div class="jb51code">
<pre class="brush:php;">
/**

  • @data 用户投票

  • 获取文章的ID,用户ID,判断该篇文章是否已经过了投票时间,再判断用户是否已经投过票

  • 写入文章对应投票用户表中(voted:文章ID),对应的文章评分加,文章详情内容中的votes统计加1

  • @author Lorne

  • @date 2017-03-03
    /
    public function article_vote(){
    $ONE_WEEK_IN_SECONDS= 7
    86400;
    $article = "article:3";
    $user = "user:7777";

    $redis = $this -> redis;
    $key= "queue";
    $cutoff = time() - $ONE_WEEK_IN_SECONDS;
    //文章发布时间和投票截止日期对比
    if($redis->zscore('time:',$key) < $cutoff){
    var_dump("该文章已过投票时间!");exit;
    }
    $article_id = explode(':',$article)['1'];
    if($redis->sadd('voted:'.$article_id,$key)){
    $redis -> zincrby('score:',$key);
    $redis -> hincrby($article,'votes',$key);
    }else{
    var_dump("您已经投过票了!");exit;
    }
    }

  • @data 文章列表分页

  • 对文章评分有序集合或者时间发布有序集合做分页处理,获取文章ID后,去文章详情散列表中查询该文章详情

  • @author Lorne

  • @date 2017-03-03
    /
    public function get_articles($page =1,$orders =''){
    $redis = $this->redis;
    $db = "queue";
    //$orders = "time:";
    $per_page = 3;
    $start = ($page-1)
    $per_page;
    $end = $start + $per_page -1;
    $ids = $redis -> zrevrange($orders,$start,$end,$db);
    foreach($ids as $key=>$val){
    $data = $redis -> hgetall($val,$db);
    $data['id'] = $val;
    $articles[] = $data;
    }
    return $articles;
    }

  • @data 文章添加组和移除组

  • 讲该文章加入不同的分组中,或者从个分组中移除该篇文章

  • @author Lorne

  • @date 2017-03-03
    */
    public function add_remove_group($article_id,$to_add = [],$to_remove = []){
    $redis = $this->redis;
    $db = "queue";
    $article = "article:".$article_id;
    foreach($to_add as $key=>$val){
    $redis -> sadd('group:'.$val,$db);
    }
    foreach($to_remove as $key=>$val){
    $redis -> srem('grouo:'.$val,$db);
    }
    }

  • @data 组集合中的文章根据评分或者时间分页排序

  • @author Lorne

  • @date 2017-03-03
    */
    public function get_grouop_articles($orders = "time:"){
    $redis = $this -> redis;
    $db = "queue";
    $group = '开发';
    $key = $orders.$group;
    if($redis -> exists($key,$db)){
    $argument = 2;
    $data = $redis -> zinterstore($key,$argument,['group:'.$group,$orders],$db);
    //$this -> expire($key,60,$db);
    }
    return $this->get_articles(2,$key);
    }

  • 采用PHP+redis,简易的实现文章发布系统,用户投票,文章分组,分页排序。

    redis是一个高性能的key-value存储系统,最为常见的5大类型:string(字符串)、list(链表)、set(集合)、zset(sorted set --有序集合)和hash(哈希类型),和memcache区别的是redis会周期性的把更新的数据写入磁盘或者把修改操作写入追加的记录文件,并且在此基础上实现了master-slave(主从)同步。

    最近越来越喜欢用上redis,有情投意合者一起多多交流呀。

    以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。

    原创声明
    本站部分文章基于互联网的整理,我们会把真正“有用/优质”的文章整理提供给各位开发者。本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
    本文链接:http://www.jiecseo.com/news/show_63577.html

    本站采用系统自动发货方式,付款后即出现下载入口,如有疑问请咨询在线客服!

    售后时间:早10点 - 晚11:30点

    咨询售后客服

    推荐精华