啦啦啦啦啦!

『居善地』接口测试 — 19.接口签名sign原理(二)

2021-01-22  本文已影响0人  繁华似锦Fighting

3、接口签名sign原理

(1)什么是接口签名?

是使用用户名密码时间戳和所有的排过序之后的参数,拼接组合起来成为一个串,再把该串加密得到的字符串,这就是一个签名。

该签名字符串是唯一的有权访问第三方接口的鉴权码。

(2)为什么需要做接口签名

  1. 防伪装攻击。
  2. 防篡改攻击。
  3. 防重放攻击。
  4. 防数据泄露 。

在为第三方系统提供接口的时候,肯定要考虑接口数据的安全问题,比如数据是否被篡改,数据是否已经过时,数据是否可以重复提交等问题。其中我认为最终要的还是数据是否被篡改。

(3)接口签名的实践方案

1)、明确请求身份

为开发者分配AccessKey(开发者标识,确保唯一)和SecretKey(用于接口加密,确保不易被穷举,生成算法不易被猜测)。

也有的人叫appidappsecret,针对不同的调用方分配不同的appidappsecret

(一般16-32位长,字母和数字组成,由开发提供。)

2)、生成signature(签名)

这串字符串就是signature(签名)

说明:

3)、接口的请求参数

已登陆接口为例:

请求参数:
{
    "username":"Jerry",
    "password":"Test123456",
    "signature":"7CB6DFDCB3BAED652BF6A09D2ACDE34F",
    "timestamp":"时间戳 " 
}

# 提示:
# signature和timestamp参数是提供实现接口加密,
# 但是不参与接口业务逻辑。

服务端收到请求的参数之后,接口会对signature进行解密和判断,是否符合请求标准。

符合标准之后就处理请求返回结果。

4)、编写测试用例

  1. 获得AccessKeySecretKey码。
  2. 通过算法获得signature(签名)。
  3. 把签名放入请求参数中。
  4. 剩余步骤与测试普通接口相同。

总结:

我们只要了解接口签名sign原理即可,关于实现代码,可以网上搜索,然后结合自己业务需求进行编码。

这里就不展示实际代码了。

上一篇 下一篇

猜你喜欢

热点阅读