PHP 对参数签名
- 对参数进行签名防止参数劫持
- 加入timestamp, 防止DOS攻击(但这次没有实现这个功能,后续再实现)
interface BaseToken
{ /**
* @param params array|string 前端请求的参数
* @param key string 秘钥
* @return sign string
*/
public function getSign($params, string $key);
} class Token implements BaseToken
{ public $privateKey = 'thisisprivateKey!!'; /**
* 后端根据前端的参数生成的签名, 签名是防止参数劫持
* 还可以判断timestamp,防止DOS攻击
* @return sign
*/
public function getSign($params, string $privateKey)
{
//有的接口可能需要判断timestamp,防止DOS攻击,判断是否传入了timestamp
if(isset($params['timestamp'])){
if(abs($params['timestamp']-time()) > 60*15){
return ['code'=>10001, 'msg'=>'timestamp失效,请重新发送请求'];
}
}
$string = '';
foreach ($params as $key => $value) {
// firstly unset value of empty
if(!$value){
unset($params[$key]);
}
}
//参数名按ASCII吗从小到大排序(字典序)
ksort($params);
$str = '';
foreach ($params as $key => $value) {
//前端请求的参数里面是包含sign的,需要过滤。,timestamp 也参与签名.
if($key != 'sign' && !is_array($value))
$str .= $key.'='.$value.'&';
}
//拼接privateKey,签名
$str .= 'key='.$privateKey;
$sign = strtoupper(md5($str));
return $sign;
} // check value is or not empty
//获取传入的参数,参数个数不确定,类型不确定
public function handle($json)
{
// $params = func_get_args(); //结果是索引数组,不是关联数组
$params = json_decode($json, true);
$sign = $this->getSign($params, $this->privateKey);
if($params['sign'] == $sign){
return 'success';
}else{
return 'sign fail';
}
}
} //模拟前端发送请求数据,使用json格式,func_get_args()返回的不是关联数组,无法使用签名。
$user = 'bneglect';
$timestamp = 1576659396; //time()
$str = '';
$str .= 'timestamp='.$timestamp.'&user='.$user.'&key=thisisprivateKey!!';
$sign = strtoupper(md5($str));
$json = ['user'=>$user, 'timestamp'=>$timestamp, 'sign'=>$sign];
$json = json_encode($json); //调用对象
$token = new Token;
echo $token->handle($json);
PHP 对参数签名的更多相关文章
- [置顶]
webapi token、参数签名是如何生成的
一个问题 在这里我想问大家一句,如果你向一个刚刚接触.net web后端程序开发的同学(别人刚刚也就学了webform的request,response,会提交表单的这种刚接触不久的同学),你怎么去解 ...
- 防盗链之URL参数签名
一.概述 传统的 IP 禁用.referer 防盗链.User-Agent 防盗链.地区访问控制等防盗链措施已经无法完全满足用户要求,所以开发出URL参数签名方式来防盗链 二.实现 Token防盗链是 ...
- C# 参数签名字符串按 ASCII码排序,注意其中的坑
参数签名中通常是按键值对中键名称的ASCII按从小到大的顺序排序后进行hash为签名字符串.不要直接使用 SortedDictionary<string, string> 有坑的,他是按数 ...
- 参数签名ascii码排序的坑
参数签名中通常是按键值对中键名称的ASCII按从小到大的顺序排序后进行hash为签名字符串.不要直接使用 SortedDictionary<string, string> 有坑的,他是按数 ...
- 【转】js生成接口请求参数签名加密
js生成接口请求参数签名加密 签名算法规则: 第一步,设所有发送或者接收到的数据为集合M,将集合M内非空参数值的参数按照参数名ASCII码从小到大排序(字典序),使用URL键值对的格式(即key1=v ...
- 防盗链之URL参数签名 总结
一.概述 传统的 IP 禁用.referer 防盗链.User-Agent 防盗链.地区访问控制等防盗链措施已经无法完全满足用户要求,所以开发出URL参数签名方式来防盗链 二.实现 Token防盗链是 ...
- webapi token、参数签名是如何生成的(转载)
API接口保障安全性原则:1.有调用者身份2.请求的唯一性3.请求的参数不能被篡改4.请求的有效时间 在刚接触接口开发时,可能脑子里压根就没有这个接口调用安全性的原则,但常识性的经验告诉我们,每一个请 ...
- js生成接口请求参数签名加密
js生成接口请求参数签名加密 定义规则:将所有参数字段按首字母排序, 拼接成key1 = value1 & key2 = value2的格式,再在末尾拼接上key = appSecret, 再 ...
- Jmeter的参数签名测试
简介 参数签名可以保证开发的者的信息被冒用后,信息不会被泄露和受损.原因在于接入者和提供者都会对每一次的接口访问进行签名和验证. 签名sign的方式是目前比较常用的方式. 第1步:接入者把需求访问的接 ...
- WebApi安全性 参数签名校验(结合Axios使用)
接口参数签名校验,是WebApi接口服务最重要的安全防护手段之一. 结合项目中实际使用情况,介绍下前后端参数签名校验实现方案. 签名校验规则 http请求,有两种传参形式: 1.通过url传参,最常见 ...
随机推荐
- nginx location 路由的几个配置纪要
1:网上没有查到在线测试 nginx location 规则的网址 在服务器上可以通过 return 返回测试比如 把#号去掉 # location /admin\.php(.*) # { #def ...
- python 2.7 环境配置
原文地址:Python 2.7的安装(64位win10) Python 2.7.12 下载地址:https://www.python.org/downloads/ 安装路径D:\Program Fil ...
- Java CountDownLatch应用
Java的concurrent包里面的CountDownLatch其实可以把它看作一个计数器,只不过这个计数器的操作是原子操作,同时只能有一个线程去操作这个计数器,也就是同时只能有一个线程去减这个计数 ...
- windows下安装mysql-8.0.18-winx64
1.下载安装包 安装包现在地址: https://dev.mysql.com/downloads/mysql/ 2.解压缩至安装目录 解压缩下载之后的zip,我这里使用的安装路径为: C:\Progr ...
- VS.NET(C#)--1.3_VS2005开始
VS2005开始 开始页 1.文件系统:这是默认,把网站创建到当前物理文件系统上(可以本地或网络).此时VS2005将使用内置的Web服务器,不使用IIS运行Web应用程序.2.HTTP使用IIS处理 ...
- vue+iview的form表单校验总结
这篇文章时关于如何使用iview的form表单校验.主要学习如何使用form校验(以校验文字长度为例),以及如何动态添加校验规则和异步校验. 1.为需要校验的表单添加form标签 <!--注意: ...
- JAVA操作ORACLE大对象
一:操作CLOB (1)数据库表结构如下: create table CLOB_TEST ( ID VARCHAR2(5) not null, ...
- 在vue项目中使用live2d
成品如图: 那么几步简单说明怎么用吧: 第一,先去github上下载相应的静态资源: https://github.com/xiazeyu/live2d-widget-models 第二,将packg ...
- js时间格式化和相互转换
1. Thu Mar 07 2019 12:00:00 GMT+0800 (中国标准时间) 转换为 2019-03-07 12:00:00 const d = new Date(Thu Mar 07 ...
- Questasim10.6c下载安装教程
questasim作为modelsim的高级版,用着速度还是比modelsim爽很多,基本上所有操作指令都是和modelsim兼容的. 不同版本的vivado兼容的modelsim版本是不一样的,如果 ...