php实现接口api数据签名及验签
发布: 来源: PHP粉丝网 添加日期:2024-03-07 14:18:23 浏览: 评论:0
api数据签名作用:通过使用签名可以验证数据在传输过程中是否被篡改或修改。接收方可以使用相同的签名算法和密钥对接收到的数据进行验证,如果验证失败则表明数据被篡改过。
1、数据发送方进行接口签名并传输签名字段
- // 请求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、接口接受方,进行数据签名并且对比签名
- $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;
- }
Tags: api数据签名 api数据验签
- 上一篇:详解如何在PHP代码里面调用Go程序
- 下一篇:最后一页
推荐文章
热门文章
最新评论文章
- 写给考虑创业的年轻程序员(10)
- PHP新手上路(一)(7)
- 惹恼程序员的十件事(5)
- PHP邮件发送例子,已测试成功(5)
- 致初学者:PHP比ASP优秀的七个理由(4)
- PHP会被淘汰吗?(4)
- PHP新手上路(四)(4)
- 如何去学习PHP?(2)
- 简单入门级php分页代码(2)
- php中邮箱email 电话等格式的验证(2)