php接口api数据签名及验签

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

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

php 复制代码
<?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 复制代码
<?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;
}
相关推荐
FL16238631293 小时前
[C#][winform]基于yolov8的水表读数检测与识别系统C#源码+onnx模型+评估指标曲线+精美GUI界面
开发语言·yolo·c#
cnxy1886 小时前
围棋对弈Python程序开发完整指南:步骤1 - 棋盘基础框架搭建
开发语言·python
上进小菜猪6 小时前
基于 YOLOv8 的驾驶员疲劳状态识别系统实战(含完整源码与可视化界面)
后端
上进小菜猪6 小时前
基于 YOLOv8 的交通标识与设施识别系统(含完整源码)
后端
大数据追光猿7 小时前
【大数据Doris】生产环境,Doris主键模型全表7000万数据更新写入为什么那么慢?
大数据·经验分享·笔记·性能优化·doris
sevenez7 小时前
Vibe Coding 实战笔记:从“修好了C坏了AB”到企业级数据库架构重构
c语言·笔记·数据库架构
智嵌电子7 小时前
【笔记篇】【硬件基础篇】模拟电子技术基础 (童诗白) 第10章 模拟电子电路读图
笔记·单片机·嵌入式硬件
程序员-周李斌7 小时前
Java 死锁
java·开发语言·后端
布列瑟农的星空7 小时前
还在手动翻译国际化词条?AST解析+AI翻译实现一键替换
前端·后端·ai编程
2301_800050997 小时前
mysql
数据库·笔记·mysql