【原创】使用simc类Base64方法解码引发的奇葩问题

在使用苹果天猫APP扫码时,服务端接收到参数,对json字符串进行解码时,总是遇到下面的报错:

而使用苹果淘宝APP则是正常。因此怀疑是天猫和淘宝APP对json格式的解析方法或者对Base64的解码方法不相同。

经过一番探究,发现在两个不同解码网站进行测试时,得到的结果竟然不一样。

使用该字符串(eyJkZXZpY2VJZCI6MiwidXNlcklkIjoxNTQ3fQ)进行测试:

  1. http://tool.chinaz.com/Tools/Base64.aspx ,提示解码失败

若对字符串末尾加上“==”,则可以正确解码:

  1. http://base64.xpcha.com/ ,则成功

对字符串末尾加上“==”,也可以正确解码:

由此,基本可以确定是解码工具不一样导致的。

检查了服务端代码,我目前使用的是sun.misc.BASE64Decoder的解码方法,

查看了几篇文章,在这篇文章中( https://blog.csdn.net/u013476542/article/details/53213783) 提到sun.misc.BASE64Decoder并不被推荐,有可能未来会被删除,

因此猜测有可能是这个工具类引起的,那就不如换个其他工具类试下。
暂定使用了文章提到的“常用的Apache Commons Codec library里面的org.apache.commons.codec.binary.Base64”。

写了一个测试方法对该字符串进行测试,

传入不加和加上“==”的两种字符串,发现果然都可以正确解码:

赶紧改了改代码,部署到服务端测试,果然正常啦!

至此,开心得感极而泣啦!昨天还花了两个小时研究,以为是前端编码入参的问题,最终还是排除了前端问题,定位在服务端方法异常。

话说回来,为什么苹果淘宝扫码可以正常,而天猫APP则不可以?
试验了下,对扫码结果进行了日志记录,终于发现了问题:
淘宝服务器和天猫服务器对参数的处理方式有差异,淘宝会对base64编码过的字符串保留==(应该是使用类似Base64.DEFAULT的方式),而天猫则默认会去掉末尾 的==(应该是使用类似Base64.NO_PADDING的方式),而恰巧使用sun.misc.BASE64Decoder则不可以解码没有==的字符串
——就是这么巧合,所以奇葩问题才会来了。

使用淘宝APP扫码:

使用天猫APP扫码:

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1、通过CocoaPods安装项目名称项目信息 AFNetworking网络请求组件 FMDB本地数据库组件 SD...
    阳明AI阅读 16,038评论 3 119
  • 关于Mongodb的全面总结 MongoDB的内部构造《MongoDB The Definitive Guide》...
    中v中阅读 32,117评论 2 89
  • 晚上,她发了一条信息给他,在么 他说在,她说哦 她悲伤了一整天,她不知道要说什么,他是她悲伤时抓住的一根稻草,她想...
    永之_阅读 799评论 0 0
  • 又一个大年夜,又离成熟和老去近了一步。 噼里啪啦,烟花绽放在空中的美丽犹如逝去的曾经。在当下,回味时,带着...
    墨寒凉阅读 1,696评论 0 0
  • 我不会告诉你 为了多看你一眼 我曾在固定的时间出现在某个路口 我不会告诉你 多少个清晨和黄昏 在你大步流星奔向学校...
    Always十月阅读 1,274评论 0 1