与第三方对接时,会存在请求参数是否被篡改的问题,这时,我们就得进行接口签名验证,防止请求参数被篡改进而影响请求结果。
参数签名算法:
1、请求参数名的字母按照升序进行非空排列,使用URL键值对的格式(key1=value1&key=value2...),拼接成字符串stringA;
如:请求参数{alterFld=null,reqTm=29, characterSet=00, onStationId=262019},排列之后stringA={characterSet=00&onStationId=262019&reqTm=29}
2、遍历stringA,将所有值拼接成stringB。
如:stringB=0026201929
3、stringB最后拼接上Secretkey得到stringC,将stringC进行md5运算,并将得到的字符串所以的字母转换成大写,得到sign值。
如:sign=DigestUtils.md5Hex(StringUtils.getBytesUnchecked(stringB.toString() + md5Key, "GBK")).toUpperCase()) .toString()
4、最后stringA拼接上sign键值对,就是发送的请求参数了。
如:requrstString={characterSet=00&onStationId=262019&reqTm=29&sign=A88G9CFF}
对方接到请求参数之后,除去sign的键值对,也做同样的算法加密。最后将得到的sign值和请求的sign值进行对比,如果两值相等表示请求参数没有被篡改,如果值不同就表示请求参数被篡改过了。
实例: