码迷,mamicode.com
首页 > Web开发 > 详细

在JSON中遇到的一些坑

时间:2018-08-02 20:55:10      阅读:276      评论:0      收藏:0      [点我收藏+]

标签:rsa加密   转义   数据   加密   转换   传参   防止   编写   需要   

今天在进行压测的时候,由于需要使用到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字符串,最好采用工具进行转换,防止此次问题的发生

在JSON中遇到的一些坑

标签:rsa加密   转义   数据   加密   转换   传参   防止   编写   需要   

原文地址:https://www.cnblogs.com/lonecloud/p/9409337.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!