用户注册场景:输入签名数据signature,appId,13位时间戳timestamp,6位随机数nonce,merchantId(非必填,本次不填)的请求参数发送给服务器,服务器返回响应数值后,校验响应数据中的signature是否一致,并且对响应数据中的data进行解密;在控制台获取resData的属性值,partnerUserNo的属性值,即用户注册成功

请求:签名计算及参数加密:

1.用户注册接口,需要对用户的nonce, times,以appSecret为密钥进行MD5加密得到签名数据;

2.将加密参数转为字符串,以appSecret为密钥,iv向量:sdkppillowserver用cbc模式的对数据进行加密;

3.将签名计算和加密后的数据放进请求参数里,并且更新原有的请求参数timestamp.

一:实现签名计算具体实现步骤如下:

(1)确定请求方法,请求地址,请求头,测试环境等参数准确;

(2)请求参数appId(找开发要),,6位随机数nonce(自己设置),timestamp(后续脚本生成),signature(后续脚本生成),填入请求Body里

(3)设置请求参数,将请求参数设置为变量datajson,由于从服务端接受的数据都是json字符串,需将它转化为对象;

var body = pm.variables.replaceIn(pm.request.body.raw);
var datajson = JSON.parse(body);

(4)签名计算,设置一个变量attrs包含nonce, times,appSecret的值,

将attrs转为字符串,以字符串形式由低到高进行排序,得到变量toSign;

const appSecret = 'rbjaiz0f9s0cohla3w8jiwo3006xxxxx';
var attrs = [appSecret, datajson.nonce];
var times = new Date().getTime(); attrs.push(times);
toSign = attrs.sort().join("");

(5)将数据使用MD5加密,由于我使用的是APIFOX,加密前需要调取crypto-js库;

在库里寻找MD5的加密算法语句如下

var CryptoJS = require("crypto-js");
const sign = CryptoJS.MD5(toSign).toString();
 
如果你不确定是否有计算出数据,可在控制台打印出来,如下:
console.log("请求参数的签名计算",sign);
以上就是签名计算的整个实现过程.
 
二:数据加密
将加密参数转为字符串,以appSecret为密钥,iv向量:sdkppillowserver用cbc模式,对数据进行aes256加密,并且进行Base64编码;

(1)将加密赋值给变量datatable,由于我们用户认证没有需要加密的参数,我们可以设置为空对象{}

const datatable = {}

(2)将对象转化为JSON字符串;

const dataString = JSON.stringify(datatable);

(3)对加密参数,appSecret,sdkppillowserver进行加密

const iv = CryptoJS.enc.Utf8.parse("sdkppillowserver");
const appSecretArr = CryptoJS.enc.Utf8.parse(appSecret);
const encryptText = CryptoJS.enc.Utf8.parse(dataString);
const encrypted = CryptoJS.AES.encrypt(encryptText, appSecretArr, { iv, mode: CryptoJS.mode.CBC, padding: CryptoJS.pad.Pkcs7 });
const encryptionData = CryptoJS.enc.Base64.stringify(encrypted.ciphertext);
console.log("加密后data数据",encryptionData); //我们通过控制台打印加密后的数据
 
三:更新请求体

(1)将加密数据,签名计算,时间戳添加到请求体中,并更新请求体.

datajson.data = encryptionData;
datajson.signature = sign;
datajson.timestamp = times;
pm.request.body.update(JSON.stringify(datajson, null, 2));
console.log("包含签名,时间戳的请求参数",datajson);   //返回给服务器的数据以JSON字符串的形式返回

以上就是请求体中签名计算和数据加密

响应后置:我们需要校验服务器返回的签名是否一致,并且对加密的数据进行破解

一:校验返回的签名数据是否一致

(1)设置变量获取响应体信息

var dataData = pm.response.json().data;
console.log("respData:",dataData)

(2)计算签名

const appSecret = 'rbjaiz0f9s0cohla3w8jiwo300xxxxxx';
var attrs = [appSecret, dataData.nonce,dataData.timestamp];
console.log("后置的签名数据:",attrs) toSign = attrs.sort().join("");
var CryptoJS = require("crypto-js");
const sign = CryptoJS.MD5(toSign).toString(); console.log("后置的签名计算",sign);

(3)断言签名是否与响应数据一致

pm.test("验证签名是否一致", function () { pm.expect(dataData.signature).to.eql(sign); });

(4)对响应数据的元素data进行解密

二:对响应数据的元素data进行解密

const iv = CryptoJS.enc.Utf8.parse("sdkppillowserver");
const arr = CryptoJS.enc.Utf8.parse(appSecret);
const base64 = CryptoJS.enc.Base64.parse(dataData.data);
const decryptText = CryptoJS.enc.Base64.stringify(base64);
const decryptionData = CryptoJS.AES.decrypt(decryptText, arr, { iv, mode: CryptoJS.mode.CBC, padding: CryptoJS.pad.Pkcs7 }).toString(CryptoJS.enc.Utf8); console.log("解密的结果展示",decryptionData);
 
 

 

如何利用Apifox通过签名计算及数据加解密进行用户认证接口测试?的更多相关文章

  1. ASP.NET Core 6框架揭秘实例演示[19]:数据加解密与哈希

    数据保护(Data Protection)框架旨在解决数据在传输与持久化存储过程中的一致性(Integrity)和机密性(confidentiality)问题,前者用于检验接收到的数据是否经过篡改,后 ...

  2. T-SQL问题解决集锦——数据加解密(2)

    原文:T-SQL问题解决集锦--数据加解密(2) 问题三.如何让指定用户可以对数据表进行Truncate操作? Truncate在对大表全删除操作时,会明显比Delete语句更快更有效,但是因为它不需 ...

  3. T-SQL问题解决集锦——数据加解密

    原文:T-SQL问题解决集锦--数据加解密 以下代码已经在SQLServer2008上的示例数据库测试通过 问题一:如何为数据进行加密与解密,避免使用者窃取机密数据? 对于一些敏感数据,如密码.卡号, ...

  4. shiro框架学习-6-Shiro内置的Filter过滤器及数据加解密

    1.  shiro的核心过滤器定义在枚举类DefaultFilter 中,一共有11个 ,配置哪个路径对应哪个拦截器进行处理 // // Source code recreated from a .c ...

  5. php利用自定义key,对数据加解密的方法

    客户端和服务端通信时,有个场景很常见,通过一个id作为url参数来回传递.假设现在业务上只有这个id标识,那么需要稍微安全一点的通信,对这个id进行加密传输,到服务端再进行解密.这里需要一个服务端进行 ...

  6. java基础/数据加解密(Mooc)

    一.消息摘要算法 常用摘要算法: 以下 (HEX)内容:bc指Bouncy Castle  |  cc指:Apache commons Codec 1.消息摘要算法MD5及MD族(MD2,MD4) 消 ...

  7. 个人永久性免费-Excel催化剂功能第62波-单元格区域内数据加解密处理,最有效地保护数据方式

    Excel的数据保护能力有限,诸如之前提及过的工作表保护.工作薄保护等,都是十分微弱的保护措施,而对于强保护的工作薄打开密码来说,它像是个总开关一样,要么全不能看,要么就全看到.有这样的场景需求,一份 ...

  8. 利用BBRSACryptor实现iOS端的RSA加解密

    背景 RSA这种非对称加密被广泛的运用于网络数据的传输,但其在iOS上很难直接实现,BBRSACryptor框架通过移植openssl实现了iOS端的RSA,本文将介绍如何使用BBRSACryptor ...

  9. Java中使用OpenSSL生成的RSA公私钥进行数据加解密

    当前使用的是Linux系统,已经按装使用OpenSSL软件包, 一.使用OpenSSL来生成私钥和公钥 1.执行命令openssl version -a 验证机器上已经安装openssl 1 open ...

  10. Java中使用OpenSSL生成公钥私钥进行数据加解密

    当前使用的是Linux系统,已经安装OpenSSL软件包. 一.使用OpenSSL来生成私钥和公钥1.执行命令openssl version -a 验证机器上已经安装openssl $ openssl ...

随机推荐

  1. windows 批量杀进程

    1 import psutil 2 from subprocess import Popen, PIPE 3 4 process_name ="bsmr.exe,fxclient.exe,F ...

  2. 整合mybatis实现简单的增删改查

    mybatis配置相关代码 配置 <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE conf ...

  3. tzoj:3613 突破包围

    http://www.tzcoder.cn/acmhome/problemdetail.do?&method=showdetail&id=3613 算出两两之间min距离,然后从起点开 ...

  4. 「DIARY」PKUSC 2021 游记

    冬令营没了但是还有夏令营 (完蛋,前两天忘写游记了,完全没想起来--最后一天补一补) 试题分析在另外一篇博客上 # Day 0 早上去机场的时候把手机落在出租车上了 (还好之后找回来了),导致我前两天 ...

  5. springsecurity 配置swagger

    最近在学习springsecurity 安全框架,具体是什么概念在这里不一一赘述了.下面呢,咱们一起搭建一下简单的springsecurity swagger 项目感受一下. 首先初始化spring ...

  6. HDK_节点开发:SOP_ComputeVisibility

    Houdini版本:18.5.596 节点概述:剔除模型在某视线方向下所有不可见面. 参数界面: 输入:三角化的模型(左),可选输入遮挡模型(右) 原理:在画布上绘制该方向上的最近深度,作为判定各面可 ...

  7. python机器学习——kmeans聚类算法

    背景与原理: 聚类问题与分类问题有一定的区别,分类问题是对每个训练数据,我给定了类别的标签,现在想要训练一个模型使得对于测试数据能输出正确的类别标签,更多见于监督学习:而聚类问题则是我们给出了一组数据 ...

  8. element UI 选择时间点(可选择某一个或者多个时间点)

    html代码如下: <el-date-picker ref="datesRef" type="dates" v-model="searchObj ...

  9. JS缓存三种方法_sessionStorage_localStorage_Cookie

    1.sessionStorage:临时的会话存储 只要当前的会话窗口未关闭,存储的信息就不会丢失,即便刷新了页面,或者在编辑器中更改了代码,存储的会话信息也不会丢失. 2.localStorage:永 ...

  10. Windows 10 ~ Jenkins 安装

    首先: jenkins是由java写的,所以在使用之前请安装好JDK(最好安装JDK1.8) 下载jenkins.war包并放到一个自己创建的目录D:\jenkins下:https://mirrors ...