[PHP] Hướng dẫn viết ứng dụng đếm số người đang online bằng PHP

Đăng bởi: Admin | Lượt xem: 4410 | Chuyên mục: PHP

Trong bài này, vncoder.vn sẽ hướng dẫn các bạn cách thức xây dựng tính năng thống kê số người đang online trên website của bạn. Chức năng này cũng khá là quan trọng, nó giúp chúng ta có cái nhìn tổng quát hơn về hệ thông của chính mình, khi chúng ta nhìn thấy số lượng người đang online mà Website của bạn đang hoạt động một cách trì trệ thì bạn có thể linh hoạt hơn trong việc điều chỉnh lại Server của bạn.


Trong bài này, vncoder.vn sẽ hướng dẫn các bạn cách thức xây dựng tính năng thống kê số người đang online trên website của bạn. Chức năng này cũng khá là quan trọng, nó giúp chúng ta có cái nhìn tổng quát hơn về hệ thông của chính mình, khi chúng ta nhìn thấy số lượng người đang online mà Website của bạn đang hoạt động một cách trì trệ thì bạn có thể linh hoạt hơn trong việc điều chỉnh lại Server của bạn. Cùng vncoder.vn làm theo các bước dưới đây nhé.

Trước hết, chúng ta khởi tạo cở sở dữ liệu như sau:

mysql> create table useronline(tgtmp INT(15) DEFAULT "0" NOT NULL ,
ip VARCHAR(50) NOT NULL ,
local VARCHAR(100) NOT NULL,
PRIMARY KEY(tgtmp),
KEY ip(ip),
KEY local(local));

Trong đó:

  • tgtmp là thời gian mà họ truy cập được tính khi họ truy vào trang web đó.

  • IP là dãy số lưu thông tin IP của họ khi viếng thăm website của chúng ta.

  • local là nơi lưu đường dẫn mà họ đang truy cập.

Khi người dùng truy cập vào trang web, chúng ta sẽ tiến hành insert thông tin của họ vào cơ sở dữ liệu với các tham số cơ bản nhưng trong database.

tgtmp được tính ra bằng hàm time(). Hàm này sẽ lấy ra thời gian hiện tại của người truy cập. Tiếp tục ta lại tính thời gian mới của họ, được tính bằng việc quy ước thời gian quy định. Cụ thể ở đây chúng ta cho là 900 giây tương đương với 15 phút truy cập của họ.

<?php
    $tg=time();
    $tgout=900;
    $tgnew=$tg - $tgout;
?>

Như vậy nếu thời gian lưu trong database mà nhỏ hơn thời gian new này thì chúng ta có thể hiểu rằng vị khách ấy đã rời khỏi website của chúng ta. Cụ thể hơn.

Ví dụ: bạn ghé thăm website đó là 7h.

Như vậy hệ thống sẽ ghi thông tin lúc đó là 7h.

Nếu sau 1 thời gian tôi không làm gì, hoặc bạn không truy cập website đó nữa thì hệ thống sẽ không ghi nhận thông tin mới. Như thế nếu bây giờ 8h và trừ đi 15 phút tôi quy ước, rõ ràng là thời gian mới hiện tại là 7h45, Thời gian này vẫn lớn hơn thời điểm lưu thông tin 7h (7h45 > 7h). Do vậy, nếu chúng thỏa điều kiện đó thì chúng ta chỉ việc xóa đi các record trong cơ sở dữ liệu là xong.

Vậy ta có code kết nối CSDL như sau:

<?php
    $conn = mysqli_connect("localhost","root","", "online") or die("can't connect");
?>

Sau đó ta tiến hành ghi nhận thông tin người dùng vào CSDL.

<?php
    $sql = "insert into useronline(tgtmp,ip,local) values('$tg','$REMOTE_ADDR','$PHP_SELF')";
    $query = mysqli_query($sql);
?>

$REMOTE_ADDR là biến môi trường dùng để lấy ra IP của người truy cập.

$PHP_SELF là biến môi trường dùng để lấy ra đường dẫn mà người dùng đang truy cập.

Tiếp đến ta tiến hành xóa record khi thời gian thực lớn hơn thời gian trong cơ sở dữ liệu.

<?php
    $sql = "delete from useronline where tgtmp < $tgnew";
    $query = mysqli_query($sql);
?>

Tiếp tục là công việc hiển thị thông tin ra bên ngoài bằng cách liệt kệ các record có trong database.

<?php
    $sql = "SELECT DISTINCT ip FROM useronline WHERE local='$PHP_SELF'";
    $query = mysqli_query($sql);
    $user = mysqli_num_rows($query);
?>

DISTINCT là cú pháp cho phép liệt kệ các dòng record mà không cho phép chúng có dữ liệu trùng lặp như cú pháp select bình thường.

Vậy chúng ta sẽ liệt kê tất cả những ip của những ai đang truy cập trên trang useronline.php.

Phần việc cuối cùng còn lại là chúng ta sẽ xuất thông tin ấy ra trình duyệt.

Và sau đây là toàn bộ nội dung code của trang useronline.php

<?php
    $tg = time();
    $tgout = 900;
    $tgnew = $tg - $tgout;
    $conn = mysqli_connect("localhost", "root", "root", "online") or die("can't connect");
    $sql="insert into useronline(tgtmp,ip,local) values('$tg','$REMOTE_ADDR','$PHP_SELF')";
    $query = mysqli_query($sql);
    $sql = "delete from useronline where tgtmp < $tgnew";
    $query = mysqli_query($sql);
    $sql = "SELECT DISTINCT ip FROM useronline WHERE local='$PHP_SELF'";
    $query = mysqli_query($sql);
    $user = mysqli_num_rows($query);
    echo "user online :$user";
?>

Kết luận

Vậy là vncoder.vn đã kết thúc bài hướng dẫn cách đếm số người đang online trên Website bằng PHP. Vui lòng để lại bình luận nếu không hiểu hoặc có câu hỏi cho vncoder.vn. Chúc các bạn thành công!.

Tài liệu tham khảo

vncoder logo

Theo dõi VnCoder trên Facebook, để cập nhật những bài viết, tin tức và khoá học mới nhất!



Khóa học liên quan

Khóa học: PHP

Xây dựng Website PHP theo MVC
Số bài học:
Lượt xem: 29473
Đăng bởi: Admin
Chuyên mục: PHP

Học lập trình PHP cơ bản
Số bài học:
Lượt xem: 19919
Đăng bởi: Admin
Chuyên mục: PHP