使用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 验证失败'; } ?>
网友回复