thinkphp点赞功能和实体设计

thinkphp点赞功能实现和实体表设计 实体表设计: id,category_id,all_ids,user_id,create_time这五个字段,分别是主键,分类ID,点赞ID,用户ID,建立时间。这里的分类ID是用于有多个点赞需求的设计,例如文章,商品,视频等。php

/**
     * Created by .
     * User: 周洪亮
     * Date: 2017/3/31
     * Time: 10:30
     * 点赞方法
     */
     public function add()
    {
        $uid              = $_SESSION['uid'];
        $article_id       = I('article_id');//文章ID
        $initial_quantity = C('THANKED_INITIAL_QUANTITY');//点赞初始数量
        $customer_logic=new CustomerLogic();
        $result           = $customer_logic->addLogic($uid, $article_id);//点赞逻辑方法
        if ($result['status'] == -1) {
            exit(json_encode($result));
        }
        if ($result['status'] == -2) {
            $data            = $result['result'];
            $del_where['id'] = $data['id'];
            $del             = $this->db->where($del_where)->delete();//删除
            if ($del) {
                $thanked_number = ThankedCount($article_id, 1, $initial_quantity);
                exit(json_encode(array('status' => 2, 'msg' => '取消点同意功', 'thanked_number' => $thanked_number)));
            }
        }
        if ($article_id != null) {
            $db_data['all_ids']     = $article_id;
            $db_data['category_id'] = 3;
        }
        $db_data['user_id']     = $uid;
        $db_data['create_time'] = date('Y-m-d H:i:s');
        $add                    = $this->db->data($db_data)->add();
        if ($add) {
            $thanked_number = ThankedCount($article_id, 1, $initial_quantity);
            exit(json_encode(array('status' => 1, 'msg' => '点同意功', 'thanked_number' => $thanked_number)));
        } else {
            exit(json_encode(array('status' => -404, 'msg' => '您的网络出现故障或咱们服务器正在维修')));
        }
    }
     /**
     * Created by .
     * User: 周宏亮
     * Date: 2017/3/30
     * Time: 18:46
     * 点赞逻辑方法
     * @param $uid 用户惟一标识
     * @param $shop_id 店铺惟一ID
     * @param $goods_id 商品惟一标识
     */
    public function addLogic($uid, $article_id = '')
    {
        if ($uid == '') {
            return array('status' => -1, 'msg' => '登陆后在点赞');
        }
        if ($article_id != null) {
            $article_find = ThankedFind($uid, $article_id, 3);//查询方法
            if ($article_find != '') {
                return array('status' => -2, 'msg' => '已点赞', 'result' => $article_find);
            }
        }
    }
    
/**
 * Created by .
 * User: 周宏亮
 * Date: 2017/3/31
 * Time: 11:07
 * 点赞,查询是否已点赞
 */
function ThankedFind($uid, $all_ids, $category)
{
    $where['user_id']     = $uid;
    $where['all_ids']     = $all_ids;
    $where['category_id'] = $category;//3是文章,1是商品,店铺2
    $find                 = M('Thanked')->where($where)->find();
    
    return $find;
}
function ThankedCount($id, $category, $initial_quantity)
{
    $where['all_ids']     = $id;
    $where['category_id'] = $category;
    $count                = M('Thanked')->where($where)->count();
    $number               = $count + $initial_quantity;
    
    return $number;
}

博客地址:zhouhongliang.cn复制代码
相关文章
相关标签/搜索