php統計線上人數的代碼 結合mysql統計線上人數

來源:互聯網
上載者:User
  1. CREATE TABLE ccol(
  2. id integer not null auto_increment, #記錄的ID
  3. ip char(15) not null, #訪問者的IP地址
  4. dtstamp datetime not null, #最後訪問時間
  5. uri char(255), #訪問者請求的URI
  6. primary key (id)
  7. );
複製代碼

然後,編寫統計用的php代碼

  1. /*

  2. 檔案:ccol.php
  3. 目的:統計同時線上瀏覽的人數
  4. edit: bbs.it-home.org
  5. */
  6. $duration=1800;
  7. require "db.php"; //自行準備,資料庫訪問類
  8. //包含DBSQL
  9. $ccol=new dbSQL;
  10. $ccol->connect();
  11. $ccol->query("DELETE FROM ccol WHERE (UNIX_TIMESTAMP(NOW())-UNIX_TIMESTAMP(dtstamp))>$duration");
  12. //刪除超過半小時的記錄
  13. $ccol->query("SELECT * FROM ccol WHERE ip='$REMOTE_ADDR'");
  14. //判斷當前的IP是否在該表中存在
  15. if ($ccol->nf())//有?
  16. {
  17. $ccol->next_record();//下移找到的記錄數組的指標
  18. $id=$ccol->f('id');
  19. $ccol->query("UPDATE ccol SET dtstamp=now(), uri='$REQUEST_URI' WHERE id=$id");
  20. //設定最後訪問時間和訪問頁面
  21. }
  22. else//沒有
  23. {
  24. $ccol->query("INSERT INTO ccol VALUES (0, '$REMOTE_ADDR', now(), '$REQUEST_URI')");
  25. }

  26. $ccol->query("SELECT COUNT(*) AS ccol FROM ccol WHERE (UNIX_TIMESTAMP(NOW())-UNIX_TIMESTAMP(dtstamp))<=$duration");

  27. //找出在半個小時內的記錄,後面的WHERE子句可有可無--超出時間的已經被刪除了
  28. $ccol->next_record()
  29. echo "線上人數:", $ccol->f('ccol');
  30. $ccol->free_result();
  31. ?>

複製代碼

調用方法,在網站的每個頁面的上面調用這個程式。例如:

  1. --index.php
  2. ...

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.