2021年1月18日21:54:39

今天在调试接口时,因为使用到了 对数据的验证签名, 就是拿元数据加 一个固定的key进行 md5等算法 算出签名 具体就详细赘述了

其中有这几个字段  

user{

        id

        addTime

        email

        password

        phone

}

接口方使用 @requestbody 将对象序列化为字符串进行加密

使用:  JSON.toJSONString(User ) 

结果为 : 

{"addTime":1610978173026,"email":"112312312","id":1,"password":"125454","phone":"12121212"}

接口推送方没有创建实体类,而是使用map手动创建的 如下:

Map<String,String> map = new LinkedHashMap<>();
map.put("addTime","1610977949556");
map.put("email","112312312");
map.put("id","1");
map.put("password","125454");
map.put("phone","12121212");
log.info(JSON.toJSONString(map));

 JSON.toJSONString(map ) 

得到的结果为:
{"password":"125454","addTime":"1610977949556","phone":"12121212","id":"1","email":"112312312"}

​​​​​​​测试代码如下:

可以看到数据已经不一致了  然后导致加密之后算出来的key 不一致 导致接口签名错误 

这里指的注意的是  JSON.toJSONString()  在对对象进行转换时, 默认按照 字母的顺序来排序的,(这里测试了,跟实体类的书写顺序和set的顺序无关)

而 对map 进行转换时, 顺序是错乱的,具体的顺序我还没找到, 

解决方案

1让调用方 建立一个请求对象在进行转换

2使用  LinkedHashMap  替换  HashMap

问题解决  加密一致 接口通过

GitHub 加速计划 / js / json
41.72 K
6.61 K
下载
适用于现代 C++ 的 JSON。
最近提交(Master分支:1 个月前 )
960b763e 3 个月前
8c391e04 6 个月前
Logo

旨在为数千万中国开发者提供一个无缝且高效的云端环境,以支持学习、使用和贡献开源项目。

更多推荐