微信官方文档有解密encryptedData的示例代码。
不友好,用微信定义的 encryptedData,iv ,就可以解密成功,为啥自己的不行,返回aes解密失败。
这个原因不好找。
看了很多热心大佬的文章才知道:
数据在前后端传输过程中,一些特殊字符会丢失,或者改变。
比如:
encryptedData中,服务器接收时,遇到空格,后面就不接收了。
iv 中,加号 自动变成空格。
都是大坑。
把握一点:
前端获取到encryptedData,加这句代码,再传给服务器。
var encryptedData = encodeURIComponent(res.encryptedData);//一定要把加密串转成URI编码
var iv = encodeURIComponent(res.iv);//一定要把加密串转成URI编码
还遇到好心人分享了这个方法,不过我觉得太局限了,还是第一种比较好。
iv到了后端,请求过程中因为编码原因+号变成了空格,用这个函数变回来。
function define_str_replace(data)
{
return str_replace(’ ‘,’+’,data);
}