How can sessions be securely managed in PHP to prevent unauthorized access?

To securely manage sessions in PHP and prevent unauthorized access, it is essential to use secure session handling techniques such as setting session cookie parameters, using HTTPS, regenerating session IDs, and validating session data on each request.

// Start a secure session
session_start([
    'cookie_lifetime' => 86400,
    'cookie_secure' => true,
    'cookie_httponly' => true,
    'use_strict_mode' => true
]);

// Regenerate session ID to prevent session fixation attacks
session_regenerate_id(true);

// Validate session data on each request
if (!isset($_SESSION['authenticated']) || $_SESSION['authenticated'] !== true) {
    // Redirect to login page or deny access
    header('Location: login.php');
    exit;
}