PHP开发API接口签名及验证

<?php

// 设置一个公钥(key)和私钥(secret),公钥用于区分用户,私钥加密数据,不能公开
$key = "c4ca4238a0b923820dcc509a6f75849b";
$secret = "28c8edde3d61a0411511d3b1866f0636";

// 待发送的数据包
$data = array(
    'username' => '[email protected]',
    'sex' => '1',
    'age' => '16',
    'addr' => 'guangzhou',
    'key' => $key,
);

// 获取sign
function getSign($secret, $data) {
    // 对数组的值按key排序
    ksort($data);
    // 生成url的形式
    $params = http_build_query($data);
    // 生成sign
    $sign = md5($params . $secret);
    return $sign;
}

// 发送的数据加上sign
$data['sign'] = getSign($secret, $data);
$data['timestamp'] = time();

/**
 * 后台验证sign是否合法
 * @param  [type] $secret [description]
 * @param  [type] $data   [description]
 * @return [type]         [description]
 */
function verifySign($secret, $data) {
    // 验证参数中是否有签名
    if (!isset($data['sign']) || !$data['sign']) {
        retrun '发送的数据签名不存在';
    }
    if (!isset($data['timestamp']) || !$data['timestamp']) {
        return '发送的数据参数不合法';
    }
    // 验证请求, 10分钟失效
    if (time() - $data['timestamp'] > 600) {
        return '验证失效, 请重新发送请求';
    }
    $sign = $data['sign'];
    unset($data['sign']);
    unset($data['timestamp]);
    ksort($data);
    $params = http_build_query($data);
    // $secret是通过key在api的数据库中查询得到
    $sign2 = md5($params . $secret);
    if ($sign == $sign2) {
        return '验证通过';
    } else {
        return '请求不合法';
    }
}
?>

  

猜你喜欢

转载自www.cnblogs.com/qhorse/p/9264860.html