当前位置: 首页 > news >正文

php接口api数据签名及验签

api数据签名作用:通过使用签名可以验证数据在传输过程中是否被篡改或修改。接收方可以使用相同的签名算法和密钥对接收到的数据进行验证,如果验证失败则表明数据被篡改过

 

1、数据发送方进行接口签名并传输签名字段 

<?php
// 请求URL
$url = "http://localhost/test22.php"; // 替换为实际的URL
// 要发送的数据
$data = array('name' => 'John Doe','email' => 'john@example.com'
);
$key="adsad123";
$data['sign']=sign($data,$key);
// 发送POST请求
$response = postRequest($url, $data);
// 处理响应
var_dump($response);function sign($array,$key)
{// 1. 对数组按键进行升序排序ksort($array);// 2. 将键值对按顺序拼接到字符串中$str = "";foreach ($array as $k => $v) {$str .= $k . $v;}// 3. 添加密钥到拼接字符串末尾$restr = $str . $key;// 4. 对拼接字符串进行SHA1加密,并转换为大写$sign = strtoupper(sha1($restr));// 5. 返回生成的签名return $sign;
}function postRequest($url, $data) {$postData = http_build_query($data);$curl = curl_init($url);curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);curl_setopt($curl, CURLOPT_POST, true);curl_setopt($curl, CURLOPT_POSTFIELDS, $postData);$response = curl_exec($curl);if ($response === false) {$error = curl_error($curl);return "cURL Error: " . $error;} else {return $response;}curl_close($curl);
}

发送的签名数据

 

2、接口接受方,进行数据签名并且对比签名

<?php$key="adsad123";
$data=$_POST;
unset($data['sign']);
$sign=sign($data,$key);if($sign==$_POST['sign']){echo '验签成功';
}else{echo '验签失败';
}function sign($array,$key)
{// 1. 对数组按键进行升序排序ksort($array);// 2. 将键值对按顺序拼接到字符串中$str = "";foreach ($array as $k => $v) {$str .= $k . $v;}// 3. 添加密钥到拼接字符串末尾$restr = $str . $key;// 4. 对拼接字符串进行SHA1加密,并转换为大写$sign = strtoupper(sha1($restr));// 5. 返回生成的签名return $sign;
}

http://www.lryc.cn/news/232679.html

相关文章:

  • 实战:给docusaurus文档网站配置Algolia 实现全站内容搜索功能-2023.11.16(已解决)
  • Ubuntu18.04安装ROS系统+turtle测试
  • UE基础篇五:动画
  • SELinux零知识学习十二、SELinux策略语言之客体类别和许可(6)
  • vscode的git 工具使用
  • 利用回溯绕过正则表达式
  • Flutter执行flutter doctor报错HTTP Host Availability
  • 全栈工程师必须要掌握的前端Html技能
  • 腾讯云服务器租用价格,腾讯云服务器租用价格多少钱一年?
  • QTableWidget 设置列宽行高大小的几种方式及其他常用属性设置
  • 【AI视野·今日CV 计算机视觉论文速览 第277期】Fri, 27 Oct 2023
  • 【教3妹学编程-算法题】购买物品的最大开销
  • 关于pandas dataframe数据转换为JSON格式存储在Redis后,读取数据时发生数据篡改的问题以及解决办法
  • Go 语言编译环境
  • Leetcode刷题详解——衣橱整理
  • 短视频ai剪辑分发账号矩阵系统(招商oem)----源头技术开发
  • Ubuntu18.04安装Loam保姆级教程
  • Rust 语言中的结构体
  • Unity开发之C#基础-异常处理(Try Catch)
  • Epoxy:跨不同数据存储的 ACID 事务
  • 鸿蒙:从0到“Hello Harmony”
  • istio安装文档
  • 修改CentOS默认mail发件人名称
  • Trigger替换Demo
  • iApp祁天社区UI成品源码 功能齐全的社区应用
  • python基于BAC0库进行bacnet IP的读写
  • CSDN每日一题学习训练——Python版(简化路径,不同的二叉搜索树)
  • milvus集合管理
  • 基于SSM的教学管理系统设计与实现
  • 【第2章 Node.js基础】2.7 Node.js 的流(一)可写流