<?php
// 设置一个密钥(secret),只有发送方,和接收方知道
/*----发送方和接收方- start ----*/
$secret = "28c8edde3d61a0411511d3b1866f0636";
/*----发送方和接收方- end ----*/
/*----发送方待发送数据- start ----*/
// 待发送的数据包
$data = array(
'username' => '123@qq.com',
'sex' => '1',
'age' => '16',
'addr' => 'zhongguo',
'timestamp' => time(),
);
// 获取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);
/*----发送方待发送数据- end ----*/
/*----接收方待处理验证数据- start ----*/
/**
* 后台验证sign是否合法
* @param [type] $secret [description]
* @param [type] $data [description]
* @return [type] [description]
*/
function verifySign($secret, $data) {
// 验证参数中是否有签名
if (!isset($data['sign']) || !$data['sign']) {
return '发送的数据签名不存在';
}
if (!isset($data['timestamp']) || !$data['timestamp']) {
return '发送的数据参数不合法';
}
// 验证请求, 10分钟失效
if (time() - $data['timestamp'] > 600) {
return '验证失效, 请重新发送请求';
}
$sign = $data['sign'];
unset($data['sign']);
ksort($data);
$params = http_build_query($data);
// $secret是通过key在api的数据库中查询得到
$sign2 = md5($params . $secret);
if ($sign == $sign2) {
return '验证通过';
} else {
return '请求不合法';
}
}
/*----接收方待处理验证数据- end ----*/
?>
PHP开发API接口签名及验证
©著作权归作者所有,转载或内容合作请联系作者
- 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
- 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
- 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
推荐阅读更多精彩内容
- 前言 互联网很危险!站点安全需要在网站设计和使用的各个方面保持警惕。 常见的站点安全威胁有 SQL注入 跨站脚本 ...
- 在实际工作中,使用PHP写api接口是经常做的,PHP写好接口后,前台就可以通过链接获取接口提供的数据,而返回的数...
- 1. 安全概述 一般的接口是裸露的、不安全的!使用post、get模拟可以轻松对api进行请求,最简单的攻击就可以...
- 在系统”字体“里设置后,菜单里的字体却没有更改,字体看着有些模糊和发虚, 需要修改主题里的配置文件,我用的是系统自...