在JSON中遇到的一些坑

今天在进行压测的时候,由于需要使用到json进行传参,并且需要在JMeter中加入少量的JSON,由于JSON在java中呈现键值对的形式,并且需要使用到“”来修饰,导致只能使用\进行转义,在发送请求的时候,还需要对相关数据进行RSA加密,很奇怪的事情发生了,编写了三个json,有两个json发送到后台后,是正常的可以进行RSA加签以及验签的,有一个JSON死活都过不去。

发现问题:一段JSON通过加签,正常,发送到服务器后,进行验签操作的时候,出现,验签不通过。

解决问题:

1. 检查公私钥是否正确,由于分析前两个秘钥是正常的,可以排除秘钥不一致的问题

2. 是否由于验证签名方法出现了问题?检查方法后发现没有问题

3. 检查JSON是否出现问题?初步检查没有问题;

JOSN通过转化后出现如下图

"{\"sequenceNo \":\"201806050054"+vars.get("quotaNo")+"\"," +
		"\"ts\":\"1318041322348\"}"

4. 再次检查JSON后发现,在sequenceNo 前面有一个空格,没有发现

5. 删除空格后,验证后成功

问题分析:

1. 由于在JSON中存在空格,暂时没有发现导致,为什么会出现这种问题?有以下几个原因:

      接口文档中存在空格;

      由于源文档中存在空格是没有问题的,但是由于在后台处理的时候,将其通过fastjson转换成了Object类,由于转换后又将Object序列化层JSON字符串后,导致空格丢失,再进行验证RSA时候导致验证不通过,导致出现上述问题。

总结:

  1. 谨慎使用JSON字符串进行拼接。

  2. 如果需要转换成JSON字符串,最好采用工具进行转换,防止此次问题的发生

posted @ 2018-08-02 19:23  lonecloud  阅读(1448)  评论(0编辑  收藏  举报
我的博客即将同步至 OSCHINA 社区,这是我的 OSCHINA ID:lonecloud,邀请大家一同入驻:https://www.oschina.net/sharing-plan/apply