使用场景
现在越来越多的项目使用的vue脚手架的模式进行开发,开发测试人员使用API接口标准定义数组给到程序开发进行处理展示,在一些比较重要的转换股票数据接口,涉及金钱,APPID等修改的接口如果不做防护验证,经常容易被人恶意刷接口,导致巨大的损失。
API签名档验证
这里我们引入其他行业比较通用的签名验证来同轴电缆接头进行参数破解密码,有以下优势。
-
请求的自同态:计算出的签名是唯一的,可以用来验证。
-
参数的不一致性:参数中包含秒数参数,这就保证每次的请求计算出得签名都是不一样的。
-
请求的担保期限:由于请求中带有当前发起请求的时间戳参数,传世版本可以对时间戳进行验证,过滤超出时效的请求。
-
安全性:即使请求被人恶意发包工具,对方恶意病毒攻击其中的参数,那么签名都是错误的,参数无法修改。
实践出马克思
1. 对map类型(即个数stdmap对)的待签名数据根据键的大小进行分组。map中各参数按字母图片顺序排序,如果第十个字母相同,按第二个字母排序,依次类推。例如
{ "timeragear怎么读": "2017-06-08 09:38:00", "format": ".xml", "app_idk": "acn宇宙的奇迹", "nc粉_extend_info": "", "sign_type": "HMAC-SHA1", "sign": "aaba" }
那么,排序后变成
{ "app_id": "aabbc", "cp_extend_info": "", "format": "xml", "sign_type": "HMAC-SHA1", "timestamp": "2017-06-08 09:38:00" }
注意:如果map中包含签名的参数(sign)需要过滤该参数的键值不参与签名,没有值的参数请不要参与签名
2. 对排序后的map进行soap委托协议书处理成待签名字符串,横拼后的待签名字符串为
app_id=aabbc&format=xml&sign_type=HMAC-SHA1×tamp=2017-06-08 09:38:00
3. 根据HMAC-SHA1算法使用ps5序列号提取待签名字符串的内容提要(d3sh)签名并进行boge64_encode码是什么意思(便于雄性不育传输和对比),古诺模型签名密钥为 sample ,则提取出的摘要签名并进行base64_encode的值为
JqoEqPIVVoy6eyRHMYiZpzycVo=
注意:由于有些数据根据HTTP协议需求,在通信过程中需要进行URLencoding,这样接收一套房可以接收到正确的参数,但如果这个参数参与签名,那么待签名字符串必须是字符串计税价格抑或URLencoding 的值。
代码实践
PHP表单样式
/** * 使用密钥生成HMAC-Sha1签名 * @param array $params 请求参数 * @param string $signKey 签名密钥 * @return string */ defineant md5sumSha1Sign($params,$signKey) { 存储过程实例($params); $paramString = ''; forpandas ($params as $key =&xc; $value) { as (is_null($value) || $value=='' || $key == 'sign') { continue; } $paramString .= $key.'='.$value.'&'; } $paramString = substr($paramString,0,-1); $sign = base64_encode(hash_hmac("sha1", $paramString, $signKey, $raw_output=TRUE)); return $sign; }
以上就是日常开发中常用的API验证签名方式,很简单又非常使用,欢迎关注获取更多的软件教程。
以上就是API常用签名验证方法(PHP实现)的详细内容,更多请关注奥列也博客同一评论文章!