douxie1894 2019-04-20 03:47
浏览 53
已采纳

如何在PHP Codeigniter中使用cookie添加Post视图计数?

I am trying to add Post view counts using cookies in PHP Codeigniter. I have created a custom library(snippetfunctions) in which I have created a function(add_count) as shown below

  public function add_count($table,$column,$value)
{

$CI =& get_instance();//CI super object
$check_visitor = $CI->input->cookie(urldecode($value), FALSE);

 $ip = $CI->input->ip_address();
// if the visitor visit this article for first time then //
//set new cookie and update article_views column  ..
//you might be notice we used slug for cookie name and ip 
//address for value to distinguish between articles  views
if ($check_visitor == false) {
    $cookie = array(
        "name"   => urldecode($value),
        "value"  => "$ip",
        "expire" =>  time() + 0,
        "secure" => false
    );

    $CI->input->set_cookie($cookie);
$CI->Constant_model->update_counter($table,$column,urldecode($value));
}
}

and I used this function in my Controller file to add the count

$this->snippetfunctions->add_count('snippets','counter_views',$slug);

Where snippets is the table name, counter_views is the column name and $slug is the URL of the post which is used to identify the post.

The error I am getting is shown in image

enter image description here

Model function

 function update_counter($table, $column, $value)
{
    // return current article views 
    $this->db->where($column, urldecode($value));
    $this->db->select('counter_views');
    $count = $this->db->get($table)->row();
    // then increase by one 
    $this->db->where($column, urldecode($value));


    $this->db->set('counter_views', ($count['counter_views'] + 1));
    $this->db->update($table);
}
  • 写回答

2条回答 默认 最新

  • dongshuo1257 2019-04-20 05:31
    关注

    Try this code, hope this helps you
    3600 seconds and it means Current Time + 1 hour, your cookie will expire in one hour

    $cookie = array(
            "name"   => urldecode($value),
            "value"  => "$ip",
            "expire" =>  3600,//changes seconds for 1 hour from current time
            "secure" => false
        );
    

    Model:

    function update_counter($table, $column, $value)
    {
        // return current article views 
        $this->db->where($column, urldecode($value));
        $this->db->select('counter_views');
        $count = $this->db->get($table)->row('counter_views');
    
        $this->db->reset_query();
        // then increase by one 
        $this->db->set('counter_views', ($count + 1));//changes
        $this->db->where($column, urldecode($value));
        $this->db->update($table);
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 SAP HANA SQL Script 。SUM OVER 怎么加where
  • ¥15 怎么获取红包封面的原始链接,并且获取红包封面序列号
  • ¥100 微信小程序跑脚本授权的问题
  • ¥60 为什么使用python对地震数据进行umap降维后,数据成图会出现不连续的现象
  • ¥100 房产抖音小程序苹果搜不到安卓可以付费悬赏
  • ¥15 STM32串口接收问题
  • ¥15 腾讯IOA系统怎么在文件夹里修改办公网络的连接
  • ¥15 filenotfounderror:文件是存在的,权限也给了,但还一直报错
  • ¥15 MATLAB和mosek的求解问题
  • ¥20 修改中兴光猫sn的时候提示失败