SESSIONphp.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 đó.
Workflow Session như sau:
82lkhj3gau4p0chl0adf0g3fvhPHPSESSID (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;
?>
Bạn là vào truy cập 1 lần vào trang
Trong đoạn code trên có sử dụng 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.inisession.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!