PHP开发API接口签名及验证

作者: 会长__ | 来源:发表于2019-03-25 20:06 被阅读0次
<?php
// 设置一个密钥(secret),只有发送方,和接收方知道
/*----发送方和接收方- start ----*/
$secret = "28c8edde3d61a0411511d3b1866f0636";
/*----发送方和接收方- end ----*/
 
 
/*----发送方待发送数据- start ----*/
// 待发送的数据包
$data = array(
  'username' => '123@qq.com',
  'sex' => '1',
  'age' => '16',
  'addr' => 'zhongguo',
  'timestamp' => time(),
);
 
// 获取sign
function getSign($secret, $data) {
  // 对数组的值按key排序
  ksort($data);
  // 生成url的形式
  $params = http_build_query($data);
  // 生成sign
  $sign = md5($params . $secret);
  return $sign;
}
 
// 发送的数据加上sign
$data['sign'] = getSign($secret, $data);
/*----发送方待发送数据- end ----*/
 
 
 
/*----接收方待处理验证数据- start ----*/
/**
* 后台验证sign是否合法
* @param [type] $secret [description]
* @param [type] $data [description]
* @return [type] [description]
*/
function verifySign($secret, $data) {
  // 验证参数中是否有签名
  if (!isset($data['sign']) || !$data['sign']) {
    return '发送的数据签名不存在';
  }
  if (!isset($data['timestamp']) || !$data['timestamp']) {
    return '发送的数据参数不合法';
  }
  // 验证请求, 10分钟失效
  if (time() - $data['timestamp'] > 600) {
    return '验证失效, 请重新发送请求';
  }
  $sign = $data['sign'];
  unset($data['sign']);
  ksort($data);
  $params = http_build_query($data);
  // $secret是通过key在api的数据库中查询得到
  $sign2 = md5($params . $secret);
  if ($sign == $sign2) {
    return '验证通过';
  } else {
    return '请求不合法';
  }
}
/*----接收方待处理验证数据- end ----*/
?>

相关文章

  • PHP开发API接口签名及验证

  • API接口签名验证

    点击访问原文您还可以加入全栈技术交流群(QQ群号:254842154) 系统从外部获取数据时,通常采用API接口调...

  • PHP开发api接口安全验证

    在实际工作中,使用PHP写api接口是经常做的,PHP写好接口后,前台就可以通过链接获取接口提供的数据,而返回的数...

  • PHP开发api接口安全验证

    php的api接口 在实际工作中,使用PHP写api接口是经常做的,PHP写好接口后,前台就可以通过链接获取接口提...

  • PHP 接口签名验证

    概览 工作中,我们时刻都会和接口打交道,有的是调取他人的接口,有的是为他人提供接口,在这过程中肯定都离不开签名验证...

  • php接口签名验证

    在做一些api接口设计时候会遇到设置权限问题,比如我这个接口只有指定的用户才能访问。 很多时候api接口是属于无状...

  • 2019-01-16-签名

    开放平台api接口签名验证说明 https://blog.csdn.net/vtopqx/article/deta...

  • 开放api接口签名验证

    你在写开放的API接口时是如何保证数据的安全性的?我们通过http Post或者Get方式请求服务器的时候,会面临...

  • 开放API接口签名验证

    一、 接口安全问题 请求身份是否合法? 请求参数是否被篡改? 请求是否唯一? 二、 AccessKey&Secre...

  • 答题吧API验证码识别接口

    答题吧API验证码识别接口介绍: 答题吧验证码识别接口API是答题吧开放给易语言软件开发者的程序接口,开发者可以通...

网友评论

    本文标题:PHP开发API接口签名及验证

    本文链接:https://www.haomeiwen.com/subject/ukxivqtx.html