对接方将3DES密钥用文本给出,我将其base64解码后的bytes来创建SecretKeySpec,报错
java.security.InvalidKeyException: Wrong key size
debug发现base64解码的bytes只有18个字节。。
后来我想是不是他将每个文本字符作为一个字节?统计了以下字符长度,确实是24。
然后直接将字符串的每个字符作为一个字节,将得到的二进制字节作为密钥,解密成功了。
通常来说,提供des密钥应该是提供二进制密钥的base64编码。这次遇到的真是个奇葩的对接方

本文讲述了作者在处理3DES密钥时遇到的困惑,对接方提供的不是标准Base64解码后的二进制密钥,而是按字符计数的24字符字符串。通过探索发现并解决了这一问题,揭示了非典型密钥格式的处理技巧。

3288

被折叠的 条评论
为什么被折叠?



