使用hash_hmac函数实现HMAC-SHA1签名算法
根据用户手机号和当前的时间加上sha1方法,Secure Hash Algorithm(安全哈希算法,函数返回一个 40位的十六进制数
function createToken($telephone)
{
return unsafe_b64encode(hash_hmac('sha1', time() . $telephone, $telephone, true));
}
function saveWebToken($telephone, $id) {
if (empty($telephone) OR empty($id)) {
return false;
}
if (!isset($redis)) {
$redis = Redis::connection('token');
}
$token = createToken($telephone);
// $type web,app
$type = 'WEB_';
$key = $type . $token;
$value = $id;
$time = 86400 * 7;
// 当前用户id ,同类型设备 是否唯一token
$flag = $redis->exists($type . $value);
if ($flag) {
$last_token = $redis->get($type . $value);
$redis->del($last_token);
}
$redis->set($key, $value);
$redis->expire($key, $time);
$redis->set($type . $value, $key);
$redis->expire($type . $value, $time);
return $token;
}