+
97
-

回答

使用hash_hmac结合时间戳实现:

<?php
// 生成加密字符串
function generateToken($data, $secretKey, $expire = 3600) {
    $timestamp = time();
    $dataString = serialize($data); // 序列化数据
    $signature = hash_hmac('sha256', $dataString . $timestamp, $secretKey);
    $token = base64_encode("$dataString.$timestamp.$signature");
    return $token;
}

// 验证加密字符串
function verifyToken($token, $secretKey, $expire = 3600) {
    $decoded = base64_decode($token);
    list($dataString, $timestamp, $signature) = explode('.', $decoded);
    $expectedSignature = hash_hmac('sha256', $dataString . $timestamp, $secretKey);
    if ($signature !== $expectedSignature) {
        return false; // 签名不匹配
    }
    if (time() - $timestamp > $expire) {
        return false; // 已过期
    }
    $data = unserialize($dataString);
    return $data;
}

// 示例
$secretKey = 'your_secret_key';
$data = array('user_id' => 123);
$token = generateToken($data, $secretKey, 600); // 有效期 600 秒
echo $token;
// 验证
if ($data = verifyToken($token, $secretKey, 600)) {
    echo 'Token 验证成功: ' . print_r($data, true);
} else {
    echo 'Token 验证失败';
}
?>

网友回复

我知道答案,我要回答