IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 开发测试 -> 简单接口验签 -> 正文阅读

[开发测试]简单接口验签

作者:recommend-item-box type_blog clearfix

后端代码

以下代码放在接口公共文件中

$apiAuth    = new ApiAuth();
$signResult = $apiAuth->verifySign();
if (!$signResult['code']) {
    $this->error($signResult['msg']);
}

ApiAuth类文件

<?php
class ApiAuth
{
    public function __construct(){
        $this->params = input();// 获取请求参数
        $this->header = $this->app->request->header();// 获取头部请求信息
        $this->appid = 'sdasdsfafjidfjfjbdfbxbfuixbfiudsbf';// 验签应用id(自定义随机字符串)
        $this->appsecret = 'ibnuigyugyuvdaskbhjbhbdhasdjhs';// 验签密钥(自定义随机字符串)
        //return $this;
    }

    /**
     * 验证签名
     * @return array
     */
    public function verifySign()
    {
        $params = $this->params;
        $header = $this->header;
        // 验证请求头部参数中是否有签名字符串
        if(!isset($header['api-sign']) && !$header['api-sign']){
            return ['code' => 0, 'msg' => '签名不存在'];
        }

        // 验证请求是否超时
        if(!isset($params['timestamp']) || empty($params['timestamp'])){
            return ['code' => 0, 'msg' => '缺少必填参数'];
        }
        $expiration = 600;// 10分钟过期
        if(time() - $params['timestamp'] > $expiration){
            return ['code' => 0, 'msg' => '验证超时,请重新发送请求'];
        }

        $oldSign = $header['api-sign'];// 请求带过来的签名
        $newSign = $this->makesign();// 现在生成签名
        // 验证签名
        if($newSign == $oldSign){
            return ['code' => 1, 'msg' => ''];
        }else{
            return ['code' => 0, 'msg' => '请求不合法'];
        }

    }

    /**
     * 生成验签
     * @return string
     */
    protected function makesign()
    {
        $params = $this->params;
        $sign = MD5(sha1($this->appid . $this->appsecret) . MD5($params['timestamp']) . sha1($this->appsecret . $this->appid));// 加密规则可按个人自定义,请求接口方也是按这种加密规则加密传递api-sign参数给接口
        return $sign;
    }

}

请求接口方(前端/小程序/第三方)

请求头部header必须带参数

header:{
	'api-sign' => $this->sign,
}

$this->sign计算方式按生成验签的规则一样,由接口方提供

$this->sign = MD5(sha1($this->appid . $this->appsecret) . MD5($params['timestamp']) . sha1($this->appsecret . $this->appid));

appid和appsecret也是由接口方提供

每个接口请求都必须带上timestamp时间戳参数

  开发测试 最新文章
pytest系列——allure之生成测试报告(Wind
某大厂软件测试岗一面笔试题+二面问答题面试
iperf 学习笔记
关于Python中使用selenium八大定位方法
【软件测试】为什么提升不了?8年测试总结再
软件测试复习
PHP笔记-Smarty模板引擎的使用
C++Test使用入门
【Java】单元测试
Net core 3.x 获取客户端地址
上一篇文章      下一篇文章      查看所有文章
加:2022-04-04 12:40:45  更:2022-04-04 12:41:02 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/18 0:26:52-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码