SESSION
php.ini : session.save_path
để lưu trữ thông tin, thông tin này được dùng chung cho tất cả các trang mà khách truy cập. Tất nhiên là mỗi khách truy cập, dựa vào thông tin trình duyệt gửi lên nó tạo một Session riêng cho khách đó.
82lkhj3gau4p0chl0adf0g3fvh
PHPSESSID
(là ánh xạ đến định danh ở trên) sẽ được gửi đến trình duyệt và trình duyệt lưu giữ PHPSESSID này, để sau đó mỗi lần trình duyệt truy cập nó gửi lại PHPSESSID cho PHP.SESSION
là cơ chế lưu trữ và phục hồi thông tin cho phiên làm việc (truy cập) của khách, nhằm trao đổi thông tin khi duyệt từ page này sang page khác. Để Session hoạt động thì còn liên quan tới hỗ trợ COOKIE
từ trình duyệt. Ví dụ trong Chrome bạn block Cookie từ facebook, thì bạn không thể đăng nhập được facebook.
session_start()
, hàm này sẽ phục hồi dữ liệu SESSION nếu đã có, nếu chưa nó sẽ tạo ra SESSION mới cho bạn. Để sử dụng khuyên nên gọi hàm này ngay khi bắt đầu của Page. Một cách khác mà không cần quan tâm đến gọi session_start()
đó là thiết lập cho PHP tự động chạy hàm này bàng cách session.auto_start = 1
trong php.ini
Biến $_SESSION:
là mảng mà SESSION lưu trữ thông tin, bạn truy cập biến này trong suốt vòng đời của session để lấy, lưu trữ thông tin. Bạn cũng nên dùng hàm isset()
để kiểm tra một biến session nào đó đã có hay chưa. Ví dụ sau dùng SESSION để đếm số lần một khách truy cập vào website.
<?php if (session_id() === '') session_start(); if( isset( $_SESSION['counter'] ) ) { $_SESSION['counter'] += 1; }else { $_SESSION['counter'] = 1; } $msg = "<p>Bạn là vào truy cập ". $_SESSION['counter'] . ' lần vào trang</p>'; echo $msg; ?>
if (session_id() === '')
để kiểm tra xem Session có tồn tại hay chưa, nếu có rồi mà bạn gọi session_start() có thể PHP sẽ cảnh báo lỗi Warning
unset
hoặc destroyed
khi hết hạn sử dụng hoặc không cần nữa. Nếu chúng ta không unset/destroyed
thì session file sẽ tồn tại mãi trên Server, trừ khi file session được xóa trên server.unset($_SESSION['counter']);
session_destroy()
<?php unset($_SESSION['name']); // dùng để xóa một giá trị session cụ thể theo name session_destroy(); // sẽ xóa bỏ toàn bộ các giá trị NAME có trong SESSION ?>
php.ini
session.use_only_cookies = 1 session.cookie_lifetime = 0 // '0' = session sẽ biến mất (hết hạn sử dụng) khi đóng trình duyệt Web Browser session.cookie_secure = 1 session.cookie_httponly = 1Trong PHP 7+, chúng ta có thể hiệu chỉnh cấu hình ngay trong hàm
session_start()
<?php session_start([ 'use_only_cookies' => 1, 'cookie_lifetime' => 0, 'cookie_secure' => 1, 'cookie_httponly' => 1 ]); ?>
/examples/sessions/dem-so-lan-truy-cap-trang-web.php
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Session trong PHP | Nền tảng VN</title> </head> <body> <h1>Session trong PHP</h1> <?php // hàm `session_id()` sẽ trả về giá trị SESSION_ID (tên file session do Web Server tự động tạo) // - Nếu trả về Rỗng hoặc NULL => chưa có file Session tồn tại if (session_id() === '') { // Yêu cầu Web Server tạo file Session để lưu trữ giá trị tương ứng với CLIENT (Web Browser đang gởi Request) session_start(); } // Nội dung file trong file session sẽ được biến $_SESSION của PHP quản lý theo dạng key=value // Truy xuất thông tin bằng cách: $_SESSION['keyname'] // Gán giá trị bằng $_SESSION['keyname'] = value; if (isset($_SESSION['counter'])) { $_SESSION['counter'] += 1; } else { $_SESSION['counter'] = 1; } $msg = '<p>Bạn đã truy cập vào trang này:' . $_SESSION['counter'] . '</p>'; echo $msg; ?> </body> </html>
Cùng nhau học tập, khám phá các kiến thức nền tảng về Lập trình web, mobile, database nhé.
Nền tảng kiến thức - Hành trang tới tương lai hân hạnh phục vụ Quý khách!
Khám phá, trải nghiệm ngay
Vui lòng đăng nhập để gởi bình luận!
Đăng nhậpChưa có bình luận nào!