1.第一种方法:

$id = $_GET['id']; //获取文章ID

$sql = "UPDATE base SET hits = hits+1 WHERE id = '$id'"; //数据库的执行语句

header("location: read.php?id=$id"); //跳转语句

给你思路,语句自己写..

数据库里除了题目,发表时间,内容这些你已经有的字段外,增加一个click字段,是用来记录被点击了多少次..

文章题目连接到一个count.php文件,用ID值传递..

然后连接数据库,把click中的值加1再保存,

然后用header函数跳转到文章显示页面,也是用ID值传递..

为了不给人恶意刷新,可以在count.php这个页面中加一个cookie,多少时间内点击视为一个点击..

2.第二种方法:
<?php
error_reporting(E_ALL);
$ROOT_PATH = '../';
include_once($ROOT_PATH . "include/config.php");

$update_time = 1800; //多长时间更新一次,单位是秒

$article_id = (isset($_GET['article_id']) && is_numeric($_GET['article_id']) && $_GET['article_id'] > 0) ? intval($_GET['article_id']) : 0; //文章的ID
if ($article_id > 0) {
    $filename = $ROOT_PATH . 'log/click_log.txt';
    $s = '';
    if (file_exists($filename)) {
        $content = file_get_contents($filename);
        $d_ary = array();
        if ($content) {
            $ary = explode("/n", $content);
            foreach ($ary as $line) {
                $data_ary = explode('|', $line);
                if (is_numeric($data_ary[0]) && is_numeric($data_ary[1])) {
                    $d_ary[$data_ary[0]] = $data_ary[1];
                }
            }
        } if (array_key_exists($article_id, $d_ary)) {
                $d_ary[$article_id] = $d_ary[$article_id] + 1; //将当前的文章的点击数加1        
             
        } else {
                $d_ary[$article_id] = 1;
             
        }
           foreach ($d_ary as $key => $val) {
                $s .= $key . '|' . $val . "/n";
              
        }
    } else {
          $s .= $article_id . '|1' . "/n"; //这个是初始化记录文件    
    }     //写记录文件    
    $fp = fopen($filename, "w"); //加入锁定
    if (flock($fp, LOCK_EX)) {
          // 进行排它型锁定
          fwrite($fp , $s);
          flock($fp , LOCK_UN); // 释放锁定
    }     //fwrite($fp, $s);    fclose($fp);    @chmod($filename, 0777);     
      $last_update = file_get_contents('../log/last_update.txt'); //取上一次更新的时间    
      $last_update = intval($last_update);
        if (($last_update + $update_time) < time()) {     //以下是数据库连接操作,我用的是ADODB,你可以改成你自己的        
          require_once("adodb.inc.php");
          $db = NewADOConnection("$DB_TYPE");
          $db->debug = true;
          $ADODB_FETCH_MODE = ADODB_FETCH_ASSOC;
            if (!$db->Connect("$DB_HOST", "$DB_USER", "$DB_PASS", "$DB_DATABASE")) {
                  exit('<a href = "/">服务器忙, 请稍候再访问</a>');        
    }         
    $content = file_get_contents($filename);        
    $d_ary = array();        
    if ($content) {            
      $ary = explode("/n", $content);            
        foreach ($ary as  $line) {                
          $data_ary = explode('|', $line);                
            if (is_numeric($data_ary[0]) && is_numeric($data_ary[1])) {                    
              $sql = "UPDATE article SET hits=hits+" . $data_ary[1] . " WHERE id=" . $data_ary[0];                    
              $db->Execute($sql);                
            }            
        }        
     }        //点击数更新完了,将这个记录文件清空        
    $fp = fopen($filename, "w");        
    fwrite($fp, '');        
    fclose($fp);        
    @chmod($filename, 0777);         //将最后一次更新时间改为当前时间        
    $fp = fopen('../log/last_update.txt', "w");      
    fwrite($fp, time());        
    fclose($fp);        
    @chmod('../log/last_update.txt  ', 0777);            
    $db->Close();//关闭数据库连接    
}    
  exit();
}?>

首先在log目录下创建last_update.txt
内容是 1155163400,(这是time()函数生成的时间)

click_log文件的内容是像下面这样的:
13136|44
13104|31
23509|32
11407|5
12141|29

第一个数字代表文章的ID,第二个数字代表累积的点击数

这样做,会提高程序的执行效率,无论是动态的PHP页面还是html里,以
<script src="click.php?article_id=333"></script>

这种方法的页面,都很有效.

这个一般用于统计文章等内容的点击数的
一般静态页里,像上面这样用的(可以把我上面的程序存成click.php)
动态页里的话,可以把上面的代码做成一个包含文件,然后在你的文章中include进来,不过,要改一下这个PHP的代码,把article_id传进去.

PHP记录点击数方法的更多相关文章

  1. MySQL把多个字段合并成一条记录的方法

    转:http://www.111cn.net/database/mysql/71591.htm MySQL把多个字段合并成一条记录的方法 在mysql中字段合并可以使用很多函数来实现,如可以利用 GR ...

  2. paip.取当天记录的方法sql跟hql hibernate

    paip.取当天记录的方法sql跟hql hibernate #------两个方法...函数法和日期计算法.. 函数法: DATEDIFF(d,createTime,GETDATE())=0   / ...

  3. MySQL查询及删除重复记录的方法

    查询及删除重复记录的方法(一)1.查找表中多余的重复记录,重复记录是根据单个字段(peopleId)来判断select * from peoplewhere peopleId in (select p ...

  4. MySQL删除重复记录的方法

    参考网上的方法,总结了产出重复记录的方法,欢迎交流. 参考:http://www.cnblogs.com/nzbbody/p/4470638.html 方法1:创建一个新表临时储存数据 假设我们有一个 ...

  5. 用一条SQL语句取出第 m 条到第 n 条记录的方法

    原文:用一条SQL语句取出第 m 条到第 n 条记录的方法   --从Table 表中取出第 m 条到第 n 条的记录:(Not In 版本)       *    FROM Table     id ...

  6. 【公众号系列】在SAP里查看条件记录的方法

    公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[公众号系列]在SAP里查看条件记录的方法   ...

  7. aop 例外通知就是记录业务方法出现错误 并保存到日志里面的功能

    aop 例外通知就是记录业务方法出现错误 并保存到日志里面的功能

  8. mysql使用GROUP BY分组实现取前N条记录的方法

    MySQL中GROUP BY分组取前N条记录实现 mysql分组,取记录 GROUP BY之后如何取每组的前两位下面我来讲述mysql中GROUP BY分组取前N条记录实现方法. 这是测试表(也不知道 ...

  9. 对于应用需要记录某个方法耗时的场景,必须使用clock_gettime传入CLOCK_MONOTONIC参数,该参数获得的是自系统开机起单调递增的纳秒级别精度时钟,相比gettimeofday精度提高不少,并且不受NTP等外部服务影响,能准确更准确来统计耗时(java中对应的是System.nanoTime),也就是说所有使用gettimeofday来统计耗时(java中是System.curre

    对于应用需要记录某个方法耗时的场景,必须使用clock_gettime传入CLOCK_MONOTONIC参数,该参数获得的是自系统开机起单调递增的纳秒级别精度时钟,相比gettimeofday精度提高 ...

随机推荐

  1. SQL Server 2000/2005 分页SQL — 单条SQL语句

    有关分页 SQL 的资料很多,有的使用存储过程,有的使用游标.本人不喜欢使用游标,我觉得它耗资.效率低:使用存储过程是个不错的选择,因为存储过程是经过预编译的,执行效率高,也更灵活.先看看单条 SQL ...

  2. project euler 12 Highly divisible triangular number

    Highly divisible triangular number Problem 12 The sequence of triangle numbers is generated by addin ...

  3. 从几个sample来学习JAVA堆、方法区、JAVA栈和本地方法栈

    最近在看<深入理解Java虚拟机>,书中给了几个例子,比较好的说明了几种OOM(OutOfMemory)产生的过程,大部分的程序员在写程序时不会太关注Java运行时数据区域的结构: 感觉有 ...

  4. JS--switch 语句

    说明:js中switch语句的语法风格 function convert(x){ switch(x) { case "string": document.write("s ...

  5. 推荐的 CSS 书写顺序

    //显示属性 display list-style position float clear //自身属性 width height margin padding border background ...

  6. Qt的十六进制的控件

    Qt没有这样的Widget,自己写一个吧.我曾经用MFC写过一个,代码不多,不到2000行,估计用Qt写不到1000行就够了. 可以参考这个qhexedit2 - QHexEdit is a Bina ...

  7. Redis应用场景-整理

    1.  MySql+Memcached架构的问题 Memcached采用客户端-服务器的架构,客户端和服务器端的通讯使用自定义的协议标准,只要满足协议格式要求,客户端Library可以用任何语言实现. ...

  8. C#/vbscript/JS如何加密保护HTML/javascript源代码

    原文地址:http://www.coding123.net/article/20121008/encrypt-javascript-by-charp-vbscript.aspx 本文通过将源代码进行u ...

  9. sqlserver 创建索引

    语法:CREATE [索引类型] INDEX 索引名称ON 表名(列名)WITH FILLFACTOR = 填充因子值0~100GO /*实例*/  CREATE NONCLUSTERED INDEX ...

  10. UESTC_One Step Two Steps CDOJ 1027

    As we all know,the handsome boy, Zcat, has a fever of flat shoes. He sings it on the class, in the d ...