版权声明:技术成长的艰难岁月,沧桑的是容颜,不变的是真心,虽然我不是特别喜欢Code ! https://blog.csdn.net/qq_25037705/article/details/81456119
在使用 System.Convert.FromBase64String 解密 时 会报异常:Base-64 字符数组的无效长度
原理:
加密字符串中的加好“+”在传参时会变成空格“ ”,所以在解密时字符串就无效了
例如:
加密字符串:dN8b8FHDK6lEz2uneeUZk+O/rrHBzaWT
传参后变成:dN8b8FHDK6lEz2uneeUZk O/rrHBzaWT
解密时:不能识别空格:抛FormatException异常
解决方案:
在Convert.ToBase64String() 加密后 使用String.Replace(“+”, “+”)将加号 替换为编码,
然后再作为参数传给另一页面传递,这样页面在提取参数时才会将“+”解码为加号
例如:
加密字符串:dN8b8FHDK6lEz2uneeUZk+O/rrHBzaWT
替换后:dN8b8FHDK6lEz2uneeUZk+O/rrHBzaWT
传参后也是:dN8b8FHDK6lEz2uneeUZk+O/rrHBzaWT
解密时:程序把”+”识别为加号 解密成功
转载自BeyondDream的博客